您的位置:首页 > 其它

两只船的装载问题

2016-06-14 16:17 211 查看
#include<iostream>
using namespace std;
int n,c1,c2,w[20],a[20];
int maxw;
void check()
{
int i,weight=0;
for(i=0;i<n;i++)
{
if(a[i])
weight+=w[i];
}
if(weight<=c1)
if(weight>maxw)
maxw=weight;//更新船1的最大装载量
}
void search(int m)
{

if(m==n)
check();
else
{
a[m]=1;//取重量为w[m]的箱子
search(m+1);//搜索下一件物品
a[m]=0;//不取
search(m+1);//搜索下一件物品
}
}
int main()
{
int i,sum;
while(cin>>c1>>c2>>n&&n)
{
maxw=sum=0;
memset(a,0,sizeof(a));
for(i=0;i<n;i++)
{
cin>>w[i];
sum+=w[i];
}
search(0);
if(sum-maxw<=c2)
cout<<maxw<<' '<<"YES"<<endl;
else cout<<"NO"<<endl;

}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: