哆啦A梦班级举办个party,当然吃的东西必不可少,哆啦A梦负责采购任务,他得到了一份清单,上面注明不同食品的受欢迎程度,哆啦A梦需要用一定的价钱尽可能达到的更大的受欢迎程度!例如,瓜子的受欢迎程度为20,瓜子的价钱是50元,那么如果哆啦A梦选择买瓜子,将花费50元,但受欢迎程度增加了20。为了避免食品单调性,每种食品只能买一份,不能重复购买。 现在哆啦A梦需要知道如何采购才能达到最大的受欢迎程度,你能帮助他吗?
输入
输入数据为多组,每组输入的第一行有两个正整数M和N(M<100&&N<1000),分别为哆啦A梦可以支配的钱数和清单上的可选择的物品种类。 接下来的N行每行有两个正整数,分别为每种物品的价钱和它的受欢迎程度(编号为1到N)。
输出
如果存在物品购买,那么输出的第一行为能够达到的最大的受欢迎程度。第二行为需要购买的物品的编号(如果有多种可能,输出字典序靠前的那种),空格分隔每个数字;如没有物品可以购买,输出只有一行,为数字0。
样例输入
10 4
100 5
5 5
5 5
10 10
样例输出
10
2 3
代码
#include<iostream>
#include<vector>
#include<string.h>
using namespace std;
int Values[1000] = {0};
int Hopes[1000] = {0};
int F[1001][101];
int max=0;
int Max(int a, int b) {
if (a < b) {
return b;
}
else {
return a;
}
}
int MFK(int n, int m) {//绘制二维表格
for (int i = 1; i <= n; i++)
{
for (int j = 1; j <= m; j++) {
if (j < Values[i])
F[i][j] = F[i - 1][j];
else {
F[i][j] = Max(F[i - 1][j], Hopes[i] + F[i - 1][j - Values[i]]);
}
}
}
return F[n][m];
}
void FindMess(int i,int j ,vector<int>&a) {//找到最优子列
while (i != 0 && j != 0) {
if (F[i][j] > F[i - 1][j]) {
a.push_back(i);
j -= Values[i];
}
i -= 1;
}
}
int main() {
int m, n, values;
vector<int>a;
while (cin >> m >> n) {
for (int i = 1; i <= n; i++) {
cin >> Values[i] >> Hopes[i];
}
a.clear();
memset(F, 0, sizeof(F));
values=MFK(n,m);
FindMess(n, m, a);
if (values == 0)
cout << '0' << endl;
else {
cout << values<<endl;
for (int i =a.size()-1; i >= 0; i--) {
if(i==0)
cout << a[i] ;
else
cout << a[i]<<' ' ;
}
cout << endl;
}
}
return 0;
}
//@author by 善良的不想你