背包问题的基本描述是: 有一个背包,能盛放的物品总重量为S,设有N件物品,其重量分别为w1,w2,...,wn.希望从N件物品中选择若干件物品,所选物品的重量之和恰能放入该背包,即所选物品的重量之和等于S。
程序1:递归算法
#include <iostream>
#include <stdlib.h>
using namespace std;
const int N=7;
const int S=20;
int w[N+1]={0,1,4,3,4,5,2,7};
int knap(int s,int n)
{
if(s==0)return 1;
if(s<0||(s>0&&n<1))return 0;
if(knap(s-w[n],n-1))
{
cout<<w[n];
return 1;
}
return knap(s,n-1);
}
int main(int argc, char *argv[])
{
if(knap(S,N))cout<<endl<<"OK"<<endl;
else cout<<"NO"<<endl;
system("PAUSE");
return 0;
}
程序2:非递归算法
#include <iostream>
#include <stdlib.h&g