链接

以前做的题 VJ太水了 数组里面的数可能会小于0 当时没判断

  1. #include <iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. #include<stdlib.h>
  6. using namespace std;
  7. int dp[],w[],path[],o,f[],n,ff[];
  8. int flag,tw;
  9. void dfs(int sw,int v,int u)
  10. {
  11. int j,i;
  12. if(flag) return ;
  13. path[v] = u;
  14. if(sw==)
  15. {
  16. flag =;
  17. for(i = ; i <= v ; i++)
  18. ff[path[i]] = ;
  19. return ;
  20. }
  21. if(sw<) return ;
  22. for(j = ; j <= n ; j++)
  23. {
  24. if(sw-w[j]<)
  25. continue;
  26. if(!f[j]&&dp[sw-w[j]])
  27. {
  28. f[j] = ;
  29. dfs(sw-w[j],v+,j);
  30. f[j] = ;
  31. }
  32. }
  33. }
  34. int main()
  35. {
  36. int i,j;
  37. cin>>tw;
  38. cin>>n;
  39. for(i = ; i <= n ; i++)
  40. cin>>w[i];
  41. dp[] = ;
  42. for(i = ; i <= n ;i++)
  43. for(j = tw ; j>=w[i] ; j--)
  44. {
  45. dp[j] += dp[j-w[i]];
  46. }
  47. int sw = tw;
  48. if(dp[tw]==)
  49. cout<<"0\n";
  50. else if(dp[tw]>)
  51. cout<<"-1\n"<<endl;
  52. else
  53. {
  54. for(i = ; i <= n ; i++)
  55. {
  56. if(sw-w[i]<)
  57. continue;
  58. if(dp[sw-w[i]])
  59. {
  60. f[i] = ;
  61. dfs(sw-w[i],,i);
  62. f[i] = ;
  63. }
  64. if(flag) break;
  65. }
  66. int kk=;
  67. for(i = ; i <= n ; i++)
  68. {
  69. if(!ff[i])
  70. {
  71. if(kk)
  72. printf(" ");
  73. printf("%d",i);
  74. kk++;
  75. }
  76. }
  77. puts("");
  78. }
  79. return ;
  80. }

URAL1244. Gentlemen(背包)的更多相关文章

  1. DP URAL 1244 Gentlemen

    题目传送门 /* 题意:已知丢失若干卡片后剩余的总体积,并知道原来所有卡片的各自的体积,问丢失的卡片的id DP递推:首先从丢失的卡片的总体积考虑,dp[i] 代表体积为i的方案数,从dp[0] = ...

  2. ural 1244. Gentlemen

    1244. Gentlemen Time limit: 0.5 secondMemory limit: 64 MB Let's remember one old joke: Once a gentle ...

  3. 【USACO 3.1】Stamps (完全背包)

    题意:给你n种价值不同的邮票,最大的不超过10000元,一次最多贴k张,求1到多少都能被表示出来?n≤50,k≤200. 题解:dp[i]表示i元最少可以用几张邮票表示,那么对于价值a的邮票,可以推出 ...

  4. HDU 3535 AreYouBusy (混合背包)

    题意:给你n组物品和自己有的价值s,每组有l个物品和有一种类型: 0:此组中最少选择一个 1:此组中最多选择一个 2:此组随便选 每种物品有两个值:是需要价值ci,可获得乐趣gi 问在满足条件的情况下 ...

  5. HDU2159 二维完全背包

    FATE Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  6. CF2.D 并查集+背包

    D. Arpa's weak amphitheater and Mehrdad's valuable Hoses time limit per test 1 second memory limit p ...

  7. UVALive 4870 Roller Coaster --01背包

    题意:过山车有n个区域,一个人有两个值F,D,在每个区域有两种选择: 1.睁眼: F += f[i], D += d[i] 2.闭眼: F = F ,     D -= K 问在D小于等于一定限度的时 ...

  8. 洛谷P1782 旅行商的背包[多重背包]

    题目描述 小S坚信任何问题都可以在多项式时间内解决,于是他准备亲自去当一回旅行商.在出发之前,他购进了一些物品.这些物品共有n种,第i种体积为Vi,价值为Wi,共有Di件.他的背包体积是C.怎样装才能 ...

  9. POJ1717 Dominoes[背包DP]

    Dominoes Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6731   Accepted: 2234 Descript ...

随机推荐

  1. lucene4.0 基于smb文件服务器的全文检索

    使用lucene 4.0版本的全文检索 所需要的jar包  网速太慢,下次有空再把jar传上来 1.FileIndex  建立索引,查询,删除,更新 package com.strongit.tool ...

  2. 11_Servlet基础知识

    [概念] Servlet通常被称为服务端小程序,是运行在服务端的程序,用于处理及相应客户端的请求. Servlet是用java语言开发网页动态资源的技术. [特点] 1.Servlet是个特殊的Jav ...

  3. Putty + Vim + Color

    Putty + Vim + Color 参考: 1.Using colour schemes with vim and putty 2.Putty的颜色 3.Custom PuTTY Color Th ...

  4. Makefile当中宏定义传递字符串

    前几天遇到类似的问题[http://bbs.chinaunix.net/thread-1589386-1-1.html]: 在Makefile里面定义一个字符串在程序里面使用, CFLAGS += - ...

  5. 安装FreeMind

    Freemind 1.0.0 官方正式版下载地址:http://dl.pconline.com.cn/html_2/1/131/id=46751&pn=0.html 软件介绍: Freemin ...

  6. Yii 关于 find findAll 查找出制定的字段的方法

    总所周知 modelName::model() -> find() //找出的是一个对象 modelName::model() -> findALL() //找出的是一个对象集合的数组 如 ...

  7. iPad知识点记录

    这两天玩了玩虚拟机安装Mac OS系统.iPad1的越狱以及利用iTunes将iPad2的系统升级到iOS8.1,这里将一些参考资源以及关键点记录一下. 一.虚拟机安装Mac OS 首先你的系统要能够 ...

  8. 我们都忽略了Html5的力量,如果只看成一种技术就大错特错了!

    第一部分:Html5市场的力量 我们太忽略Html5的市场力量了.如果你把Html5当作一种技术,就大错特错了!忘掉你的产品,忘掉你的技术,想想移动时代的信息传播和消费场景.作为2B,我们实在是没有重 ...

  9. POJ2255二叉树

    题目大意就是给出你一个二叉树的前序和中序,要你求后序. 思路:二叉树的排序就是根据根节点的位置来定义的.所以找到二叉树的根节点是最重要的,二叉树的左子树和右子树也可以看成是二叉树,以此递归: #inc ...

  10. Linux_Struct file()结构体

    struct file结构体定义在/linux/include/linux/fs.h(Linux 2.6.11内核)中,其原型是:struct file {        /*         * f ...