HDU 2191 揹包問題

2021-06-25 10:14:08 字數 1342 閱讀 5112

description

急!災區的食物依然短缺! 

為了挽救災區同胞的生命,心繫災區同胞的你準備自己採購一些糧食支援災區,現在假設你一共有資金n元,而市場有m種大公尺,每種大公尺都是袋裝產品,其**不等,並且只能整袋購買。 

請問:你用有限的資金最多能採購多少公斤糧食呢? 

後記: 

人生是乙個充滿了變數的生命過程,天災、人禍、病痛是我們生命歷程中不可預知的威脅。 

月有陰晴圓缺,人有旦夕禍福,未來對於我們而言是乙個未知數。那麼,我們要做的就應該是珍惜現在,感恩生活―― 

感謝父母,他們給予我們生命,撫養我們**; 

感謝老師,他們授給我們知識,教我們做人 

感謝朋友,他們讓我們感受到世界的溫暖; 

感謝對手,他們令我們不斷進取、努力。 

同樣,我們也要感謝痛苦與艱辛帶給我們的財富~ 

輸入資料首先包含乙個正整數c,表示有c組測試用例,每組測試用例的第一行是兩個整數n和m(1<=n<=100, 1<=m<=100),分別表示經費的金額和大公尺的種類,然後是m行資料,每行包含3個數p,h和c(1<=p<=20,1<=h<=200,1<=c<=20),分別表示每袋的**、每袋的重量以及對應種類大公尺的袋數。

output

對於每組測試資料,請輸出能夠購買大公尺的最多重量,你可以假設經費買不光所有的大公尺,並且經費你可以不用完。每個例項的輸出佔一行。

sample input

1

8 22 100 4

4 100 2

sample output

400 

#include #include #include using namespace std;

#define max_m 105

#define max_s 105//種類的最大數目

//dp[i+1][j]的定義:前i中大公尺中選出花費為k的所獲得的最大重量

int dp[max_s][max_s];

int n;//代表可用的經費

int m;//代表大公尺的種類數目

int p[max_s];//每種大公尺的**

int h[max_s];//每袋的重量

int c[max_s];//每種大公尺的個數

int main()}}

int res=0;

for(int i=0;i<=n;i++)

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

}

HDU 2191 多重揹包問題

題目資訊 problem description 急!災區的食物依然短缺!為了挽救災區同胞的生命,心繫災區同胞的你準備自己採購一些糧食支援災區,現在假設你一共有資金n元,而市場有m種大公尺,每種大公尺都是袋裝產品,其 不等,並且只能整袋購買。請問 你用有限的資金最多能採購多少公斤糧食呢?input ...

HDU 2191多重揹包問題

1 include2 include3 include4 include5 const int qq 2000 50 6 intv qq w qq dp qq 7using namespace std 8int main 929 if tot 33 34for int i 1 ii 35for in...

HDU 2191 多重揹包

problem description 急!災區的食物依然短缺!為了挽救災區同胞的生命,心繫災區同胞的你準備自己採購一些糧食支援災區,現在假設你一共有資金n元,而市場有m種大公尺,每種大公尺都是袋裝產品,其 不等,並且只能整袋購買。請問 你用有限的資金最多能採購多少公斤糧食呢?後記 人生是乙個充滿了...