我现在TMD连dfs都不会写了

原题:

MM 虽然一辈子只要一个,但是也得早点解决。于是,n 个光棍们自发组成了一个光棍组织
(ruffian organization,By Wind 乱译)。现在,光棍们打算分成几个小组,并且分头为 找 MM 事业做贡献(For example:searching,hunting……By Wind 乱译)。
对于这 n 个光棍的任意一个组合,都有一个被称为“和谐度”的东西,现在,他们想知道, 如何分组可以使和谐度总和最大。
每个光棍都必须属于某个分组,可以一个人一组。

n<=16

恩,把个中分组的方案和价值都直接给了,然后让选择的方案全部&起来等于(1<<n)-1(当然不能有冲突),DP想不到方法,n<=16似乎可以搜索

最开始做的时候是bfs,每次从1到(1<<n)-1找不冲突的方案,这样会T得很惨(至少要((1<<n)-1)^2)

然后容易想到是因为遍历1到(1<<n)-1过程中无效的枚举太多,所以可以直接dfs有效的状态

然后dfs傻逼了写了两天

原来写的:for(int i=z;i<n;i++)if(y&power2[i])  dfs(x,y-power2[i],i+1),dfs(x,y,i+1);

实际上应该是酱紫:if(y&power2[z])dfs(x,y-power2[z],z+1);  dfs(x,y,z+1);

原来的内种写法会有非常多的重复

在发现dfs有问题之前一直在怀疑是用了不正确的写法,参考了chad的题解又写了个分治(反向dfs)的,然后才发现dfs制杖了(分治的应该也对了)

经实测,bfs的时候搞一个spfa中的visited来表示这个元素是否在队中,如果在队中就不进队,这个优化效果还是不错的

尝试反向可以是突破点,比如反向搜索,反向枚举,甚至反向DP

代码(分治的丢了):

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. #include<cstring>
  5. #include<cmath>
  6. using namespace std;
  7. int read(){int z=,mark=; char ch=getchar();
  8. while(ch<''||ch>''){if(ch=='-')mark=-; ch=getchar();}
  9. while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
  10. return z*mark;}
  11. int n,a[]; int power_top;
  12. long long f[];
  13. int dui[],tou=; bool visited[];
  14. int power2[]; void get_power2(){power2[]=;for(int i=;i<=;i++)power2[i]=power2[i-]<<;}
  15. void dfs(int x,int y,int z){
  16. if(z==n){
  17. if(f[x|y]<f[x]+a[y]){ f[x|y]=f[x]+a[y];
  18. if(!visited[x|y]) dui[++tou]=x|y,visited[x|y]=true;}
  19. return ;}
  20. if(y&power2[z])dfs(x,y-power2[z],z+); dfs(x,y,z+);}
  21. void bfs(){
  22. memset(visited,,sizeof(visited));
  23. dui[tou=]=; f[]=; visited[]=true;
  24. for(int k=;k<=tou;k++) dfs(dui[k],power_top^dui[k],),visited[dui[k]]=false;}
  25. int main(){//freopen("ddd.in","r",stdin);
  26. memset(f,-,sizeof(f));
  27. get_power2();
  28. cin>>n; power_top=(<<n)-;
  29. for(int i=;i<=power_top;i++) a[i]=read();
  30. bfs();
  31. cout<<f[power_top]<<endl;
  32. //cout<<tou<<endl;
  33. return ;
  34. }

P1382 光棍组织的更多相关文章

  1. JZYZOJ 1382 光棍组织 状压dp

    http://172.20.6.3/Problem_Show.asp?id=1382   水得过分了,本来以为要用lzx学长的写法写,抱着试试看的想法写了个特暴力的dp+dfs,过了,真是...   ...

  2. TODO:GitHub创建组织的步骤

    TODO:GitHub创建组织的步骤 使用GitHub进行团队合作,写这个步骤主要作用是为了OneTODO作为一个团队组织进行代码的分享,让更多人来参与. 使用帐号.密码登录GitHub 2.右上角加 ...

  3. 【组织级项目管理】P2 MSP P3O

    组织级项目管理--有你,有我,有大家 在过去的2年,无论对于企业来讲,还是对于我们个人都有很多大脑的冲击,有几个词大家应该特别耳熟能详:转型,变革,敏捷,互联网+,组织的项目化管理等.就是这些让我们的 ...

  4. 【SAP业务模式】之ICS(四):组织单元的配置

    SAP的ICS业务后台配置主要有以下几个配置点: 1.组织单元的配置(公司代码.销售组织.工厂.采购组织等): 2.主数据的部分: 3.订单和开票的定价过程: 4.开票输出类型: 5.公司间发票的配置 ...

  5. ASP.NET MVC5+EF6+EasyUI 后台管理系统(41)-组织架构

    系列目录 本节开始我们要实现工作流,此工作流可以和之前的所有章节脱离关系,也可以紧密合并. 我们当初设计的项目解决方案就是可伸缩可以拆离,可共享的项目解决方案.所以我们同时要添加App.Flow文件夹 ...

  6. Atitit.uke 团队建设的组织与运营之道attilax总结

    Atitit.uke 团队建设的组织与运营之道attilax总结 1. intro引言:2 2. aims组织成立宗旨2 1.1. Mission组织使命2 1.2. val核心价值观2 1.3. c ...

  7. Atittit.研发公司的组织架构与部门架构总结

    Atittit.研发公司的组织架构与部门架构总结 1. archi组织架构与 部门规划2 1.1. 最高五大组织机构2 1.2. 宗教事务部2 1.3. 制度与重大会议委员会2 1.4. 纠纷处理部: ...

  8. iOS 小谈开发者中的个人、组织(公司、企业)账号

    苹果对开发者主要分为3类:个人.组织(公司.企业).教育机构.即: 1.个人(Individual) 2.组织(Organizations) 组织类又分为2个小类: (1)公司(Company) (2 ...

  9. Atitit.css 规范 bem  项目中 CSS 的组织和管理

    Atitit.css 规范 bem  项目中 CSS 的组织和管理 1. 什么是BEM?1 1.1. 块(Block)2 1.2. 元素(Element)2 1.3. BEM树(和DOM树类似).3 ...

随机推荐

  1. 进程间通信--pipe

    管道的两种局限性: 历史上,他们是半双工的(即数据只能够在一个方向上流动). 现在某些系统也提供全双工管道,但是为了最佳的移植性,我们决不应该预先假定系统使用此特性 他们只能够在具有公共祖先的进程间使 ...

  2. 杭电ACM1005

    Number Sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  3. tail 显示文件最后若干行内容

    功能:tail命令可以输出文件的尾部内容,默认情况下它显示文件的最后十行.显示每个指定文件的最后10 行到标准输出.若指定了多于一个文件,程序会在每段输出的开始添加相应文件名作为头.如果不指定文件或文 ...

  4. Qt之Qwt学习之安装

    QWT+qtcreator 编译.安装使用 目录:一.Qwt简介 二.QWT编译 一.Qwt简介 QWT:Qt Widgets for Technical Applications,是开源的2D绘图库 ...

  5. js限制文本框只能输入数字方法小结(转)

    这篇文章主要分享下js代码限制文本框中只能输入数字的多个实例,学习下js控制文本框中输入数字的方法,需要的朋友可以参考下   有时需要限制文本框输入内容的类型,本节分享下正则表达式限制文本框只能输入数 ...

  6. eclipse为方法添加注释的快捷键是什么

    /** * 登录验证 * @param 传入的vo类 * @return * @throws Exception */这种注释快捷键?   先敲“/”在敲两个**,然后回车

  7. fzu2028

    //Accepted 7324 KB 203 ms /* source:fzu2028 time :2015.5.29 by :songt */ /*题解: 树链剖分 单点更新,求路径和 */ #in ...

  8. cocos2d-x WebSocket

    WebSocket是HTML5开始提供的一种浏览器与服务器间进行全双工通讯的网络技术.在WebSocket API中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道 ...

  9. 微软How old do I Look——初体验

    前段时间微软发布了一个可爱的网站how old.net,着实火了一把,全民体验魔镜魅力. 上传自己的靓照到http://www.how-old.net/,它就可以告诉你性别和年龄,大家还习惯称之为“颜 ...

  10. HDU 5384 AC自动机

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=5384 题意:给n个母串,给m个匹配串,求每个母串依次和匹配串匹配,能得到的数目和. 分析:之前并不知道AC ...