飯卡 hdu2546(01揹包)

2022-05-11 10:35:04 字數 1047 閱讀 1798

這是乙個變形的01揹包問題,首先如果金額小於5元,剩餘金額不變,為已有金額。如果大於等於5元
我們先用5元買最貴的菜。然後用剩下的錢買其他的菜這時就是乙個典型的01揹包問題了;
求出最大的花費,然後用總金額減去最大的花費即為剩餘金額。

#include#include

#include

#include

using

namespace

std;

#define inf 0xfffffff

#define n 1005

inta[n], dp[n][n];

intmain()

m-=5

; sort(a+1, a+n+1

);

for(int i=1; i)

}printf(

"%d\n

", m+5-dp[n-1][m]-a[n]);

}return0;

}

二維陣列

#include#include

#include

#include

using

namespace

std;

#define inf 0xfffffff

#define n 1005

inta[n], dp[n];

intmain()

m-=5

; sort(a+1, a+n+1

);

for(int i=1; i)

}printf(

"%d\n

", m+5-dp[m]-a[n]);

}return0;

}

一維陣列

飯卡 HDU 2546(01揹包)

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

飯卡 HDU 2546 01揹包變形

題意 對於飯卡裡的餘額,如果少於5元,那麼不能買任何東西,5元,可以買任意乙個東西,甚至讓飯卡的餘額變成負的。現在已知飯卡的餘額m,n種菜的 思路 最貴的那個肯定最後買,讓n 1個菜盡量接近5就可以。01揹包的變形,在n 1個物品中抽取任意個,使得所花的錢盡可能接近m 5。讓價值和體積相等。求出體積...

hdu2546 01揹包理解

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