问题描述:
小明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间。更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过N元钱就行”。今天一早小明就开始做预算,但是他想买的东西太多了,肯定会超过妈妈限定的N元。
于是,他把每件物品规定了一个重要度,分为5等:用整数1~5表示,第5等最重要。他还从因特网上查到了每件物品的价格(都是整数元)。他希望在不超过N元(可以等于N元)的前提下,使每件物品的价格与重要度的乘积的总和最大。
设第j件物品的价格为v[j],重要度为w[j],共选中了k件物品,编号依次为j1,j2,……,jk,则所求的总和为:
v[j1]*w[j1]+v[j2]*w[j2]+ …+v[jk]*w[jk]。(其中*为乘号)
请你帮助小明设计一个满足要求的购物单。
初看这个问题,和0-1背包问题很相似,可以采用动态规划方法来求解:什么是动态规划(DP)?
非常重要!,不要认为概念不重要,理解的深刻,你才知道对于什么样的问题去考虑有没有动态规划的方法,以及如何去使用动态规划。
1)动态规划是运筹学中用于求解决策过程中的最优化数学方法。 当然,我们在这里关注的是作为一种算法设计技术,作为一种使用多阶段决策过程最优的通用方法。它是应用数学中用于解决某类最优化问题的重要工具。
2)如果问题是由交叠的子问题所构成,我们就可以用动态规划技术来解决它,一般来说,这样的子问题出现在对给定问题求解的递推关系中,这个递推关系包含了相同问题的更小子问题的解。动态规划法建议,与其对交叠子问题一次又一次的求解,不如把每个较小子问题只求解一次并把结果记录在表中(动态规划也是空间换时间的),这样就可以从表中得到原始问题的解。
由于动态规划具备最优子结构的性质,这意味着它属于递归的一种。
#include "OJ.h"
#include <stdlib.h>
int** initStateMatrix(int*p)
{
int** StateMatrix=(int **)malloc(sizeof(int*)*(*(p+1)));
int No=0,money=0;
//int 状态矩阵
for(No=0;No<=*(p+1);No++)
{
StateMatrix[No]=(int*)malloc(*p*sizeof(int));
for(money=0;money<=*p;money++)
{
StateMatrix[No][money]=0;
}
}
for(No=1;No<=*(p+1);No++)
{
for(money=1;money<=*p;money++)
{
if(*(p+No*2)<=money)
{
StateMatrix[No][money]=StateMatrix[No-1][money]>(StateMatrix[No-1][money-*(p+No*2)]+(*(p+No*2)*(*(p+No*2+1))))?StateMatrix[No-1][money]:StateMatrix[No-1][money-*(p+No*2)]+(*(p+No*2)*(*(p+No*2+1)));
}
else StateMatrix[No][money]=StateMatrix[No-1][money];
}
}
return StateMatrix;
}
/*
功能:
输入参数:int*p 指向二维数组的首地址,该二维数组第0行的两个数分别表示:总钱数<30000,和希望购买物品的个数<25;
该数组从第1行到第m行(1<=j<=m)中给出了编号为j的物品的基本数据,每行有2个非负整数,
表示该物品的价格(<=10000)和该物品的重要度(1~5)。
GetResult表示不超过总钱数的物品的价格与重要度乘积的总和的最大值(<100000000)。
不需做入参检查,测试用例可以保证~
例如:4000 8(第0行)
821 3 (第1行)
422 5
458 5
500 3
200 2
430 4
530 3
239 3
则表示 总钱数为4000,希望购买物品个数为8个,因此从第1行到第8行表示编号为j的物品的价格及物品的重要度。
返回值:无
温馨提示:根据题意可知,该二维数组只有两列,且行数为第0行的第二个元素数值+1;入参p不能按照二维数组的方法来取值,要将
二维的转换成一维的哦~
*/
void GetResult(int*p,int& Get_Result)
{
//在这里实现功能
int i;
int** StateMatrix=initStateMatrix(p);
for(int i=0;i<=*(p+1);i++)
{
Get_Result=StateMatrix[i][*p]>Get_Result?StateMatrix[i][*p]:Get_Result;
}
}