C++动态规划之背包问题

wb_coder 2016-03-20 04:39:37
#include<iostream>
using namespace std;
int main()
{int n,M,w[10],p[10],i,j,num;
while(cin>>n>>M){
num=0;
for(i=0;i<n;i++)
cin>>w[i]>>p[i];
int **jp;//jp是动态规划表
jp=new int*[n];

for(i=0;i<n;i++){
jp[i]=new int[M+1];
for(j=0;j<=M;j++)
jp[i][j]=0;}//初始化jp

for(j=0;j<=M;j++)
jp[n-1][j]=(j<w[n-1])?0:p[n-1];//初始化jp表的最后一行
int tw,tv,k;
for(j=n-2; j>=0; j--) //从倒数第2件开始填倒数第2行
{
tw=w[j];tv=p[j];//记录当前物品信息
for(k=0;k<=M;k++){
if((k>=tw)&&jp[j+1][k]<jp[j+1][k-tw]+tv)jp[j][k]=jp[j+1][k-tw]+tv;
else jp[j][k]=jp[j+1][k];}}
/*
cout<<"填充后的jp表格"<<endl;
for(i=0;i<n;i++){
for(j=0;j<=M;j++)
cout<<jp[i][j]<<" ";
cout<<endl;
}*/
tw=M;
for(i=0;i<n-1;i++)//查从第0件到第n-2件物品是否被使用
{if(jp[i][tw]!=jp[i+1][tw]){tw-=w[i];num++;}}
if(tw>=w[n-1])num++;//检查最后一件物品是否被用
cout<<num<<endl;
}
return 0;}这个是我自己用动态规划写的背包问题的代码,测试了很多组值结果都是对的,不知道为啥每次在学校的OJ上提交都会wrong answer.大神们帮我看下吧
...全文
303 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2016-03-21
  • 打赏
  • 举报
回复
递推公式有误。我猜。

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧