HDU NO 2546 飯卡(區間貪心)

2021-07-10 04:35:21 字數 1177 閱讀 9628

問題描述:

description

電子科大本部食堂的飯卡有一種很詭異的設計,即在購買之前判斷餘額。如果購買乙個商品之前,卡上的剩餘金額大於或等於5元,就一定可以購買成功(即使購買後卡上餘額為負),否則無法購買(即使金額足夠)。所以大家都希望盡量使卡上的餘額最少。 

某天,食堂中有n種菜**,每種菜可購買一次。已知每種菜的**以及卡上的餘額,問最少可使卡上的餘額為多少。 

input

多組資料。對於每組資料: 

第一行為正整數n,表示菜的數量。n<=1000。 

第二行包括n個正整數,表示每種菜的**。**不超過50。 

第三行包括乙個正整數m,表示卡上的餘額。m<=1000。 

n=0表示資料結束。 

output

對於每組輸入,輸出一行,包含乙個整數,表示卡上可能的最小餘額。

sample input

1505

101 2 3 2 1 1 2 3 2 1

500

sample output

-45

32

思路:

我們只需拿出5元錢買最貴的菜,那麼剩下的就轉化成01揹包問題了。

**:

#include#include#include#include#include#include#include#include#include#include#includeusing namespace std;

#define x first

#define y second

#define pi 3.1415926

const int max = 2000;

const int inf = 0x3f3f3f3f;

int dp[max];

int main()

int m;

scanf("%d", &m);

if(m < 5)

printf("%d\n", m);

else

}printf("%d\n", m - a[n-1] - dp[m-5]);}}

return 0;

}

HDU NO 2546 素數回文(篩選法求素數表)

問題描述 description xiaoou33對既是素數又是回文的數特別感興趣。比如說151既是素數又是個回文。現在xiaoou333想要你幫助他找出某個範圍內的素數回文數,請你寫個程式找出 a 跟b 之間滿足條件的數。5 a b 100,000,000 input 這裡有許多組資料,每組包括兩...

杭電 2546 飯卡

problem description 電子科大本部食堂的飯卡有一種很詭異的設計,即在購買之前判斷餘額。如果購買乙個商品之前,卡上的剩餘金額大於或等於5元,就一定可以購買成功 即使購買後卡上餘額為負 否則無法購買 即使金額足夠 所以大家都希望盡量使卡上的餘額最少。某天,食堂中有n種菜 每種菜可購買一...

HDU 2546 飯卡 題解

電子科大本部食堂的飯卡有一種很詭異的設計,即在購買之前判斷餘額。如果購買乙個商品之前,卡上的剩餘金額大於或等於5元,就一定可以購買成功 即使購買後卡上餘額為負 否則無法購買 即使金額足夠 所以大家都希望盡量使卡上的餘額最少。某天,食堂中有 n 種菜 每種菜可購買一次。已知每種菜的 以及卡上的餘額,問...