hdu1059(多重背包)
2016-04-06 21:04
204 查看
链接:点击打开链接
题意:给出价值为1~6的硬币的金额,问是否正好能够取出总价值一半的硬币
代码:
题意:给出价值为1~6的硬币的金额,问是否正好能够取出总价值一半的硬币
代码:
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <iostream> #include <algorithm> using namespace std; int a[10],used[200005],f[200005]; int main(){ int i,j,cas,sum,sign; cas=1; while(scanf("%d%d%d%d%d%d",&a[0],&a[1],&a[2],&a[3],&a[4],&a[5])!=EOF&&(a[0]||a[1]||a[2]||a[3]||a[4]||a[5])){ sum=sign=0; for(i=0;i<6;i++) sum+=(i+1)*a[i]; if(sum%2){ //奇数直接输出 printf("Collection #%d:\nCan't be divided.\n\n",cas++); continue; } memset(f,0,sizeof(f)); f[0]=1; for(i=0;i<6;i++){ //多重背包 memset(used,0,sizeof(used)); for(j=i+1;j<=sum;j++){ if(!f[j]&&f[j-(i+1)]&&used[j-(i+1)]<a[i]){ f[j]=1; used[j]=used[j-(i+1)]+1; if(j==sum/2){ //满足时即跳出 sign=1; goto next; } } } } next: if(sign) printf("Collection #%d:\nCan be divided.\n\n",cas++); else printf("Collection #%d:\nCan't be divided.\n\n",cas++); } return 0; }
相关文章推荐
- TemplateBinding 注意事项
- PHP中COOKIE及时生效,不用刷新就可以使用
- 网络编程(1)
- 130.石子归并
- adb shell am start权限问题解决
- HALCON形状匹配
- 87. Repeated DNA Sequences
- ubuntu 安装搜狗输入法
- Struts2官网翻译
- Apache访问日志分类
- power(x,n)
- PCL+Qt+VS可视化点云
- Python学习4_CentOS6.5下Pip8.1.1安装
- VC实现解压和压缩相关代码
- android基础总结
- TCP三次握手的思考,为什么要有三次握手
- 重磅开源:TN文本分析语言
- 价值观作业
- PHP判断键值数组是否存在,使用empty或isset或array_key_exists(转)
- SDAU 搜索专题 07 Cable master