题意:有N台服务器,全部服务器都直接运行着完全相同的N个任务。对于每台电脑,你都可以进行“一次”操作,使得某(自己选定)一种任务停止,且同时会使得其他和这台服务器直接相连的电脑上面相同的服务完全终止。问题是:能够使得几种不同的任务完全消失在这N个服务器当中。

数学模型:选择若干个给定的子集,最多可以将全集覆盖多少次。

首先,使用整数来表示不同的集合,理由是正好对应了,1,0两种不同的数值,也可以分别对应选取和不选两种不同的状态。

因而,此处首先使用整数来代指选了的电脑的集合——010代表选择1号机器其十进制值是2.

因而,我们可以进行强行穷举:设DP[I]选择I代表的集合可以得到的最覆盖次数。可以得到一个性质,如果DP[I]的值不为0,就意味着集合I至少覆盖了全集一次,否则应当认为,其不构成全集一次。

于是,枚举所有能够构成全集的子集和,认为,当前状态应当为,至少构成了一次的全集的子集的补集的DP值+1,从中找到一个最大的。

自己也被绕进去了。。GG看代码吧

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3.  
  4. const long long MAXN=;
  5. long long f[MAXN];
  6. long long cover[MAXN];
  7. long long p[];
  8. int n,ans;
  9.  
  10. void init()
  11. {
  12. // memset(f,0,sizeof(f));
  13. for(int i=;i<n;++i)
  14. {
  15. p[i]=(<<i);
  16. int x,m;
  17. cin>>m;
  18. while(m--)
  19. {
  20. cin>>x;
  21. p[i]|=(<<x);
  22. }
  23. }
  24. int limit=<<n;
  25. for(int s=;s<limit;++s)
  26. {
  27. cover[s]=;
  28. f[s]=;
  29. for(int j=;j<n;++j)
  30. {
  31. if(s&(<<j))cover[s]|=p[j];
  32. }
  33. }
  34. f[]=;
  35. long long ALL=(<<n)-;
  36. for(int s=;s<limit;++s)
  37. {
  38. for(int ss=s;ss;ss=(ss-)&s)
  39. if(cover[ss]==ALL)f[s]=max(f[s],f[ss^s]+);
  40. }
  41. ans=f[ALL];
  42. }
  43.  
  44. int main()
  45. {
  46. cin.sync_with_stdio(false);
  47. long long kk=;
  48. while(cin>>n&&n)
  49. {
  50. init();
  51. cout<<"Case "<<kk++<<": "<<ans<<endl;
  52. }
  53.  
  54. return ;
  55. }

UVA11825 Hacker's Crackdown 二进制集合+关于子集的动态规划的更多相关文章

  1. 算法笔记-- 二进制集合枚举子集 && 求子集和 && 求父集和

    枚举子集: 复杂度:O(2^k) )&s); 用sos dp求解子集和以及父集和 子集和: ; i <= k; i--) { ; mask < (<<k); mask+ ...

  2. python 实现求一个集合的子集

    概要 今天偶然看到有个关于数学中集合的问题,就突发奇想的想用python实现下求一个集合的子集. 准备 我当然先要复习下,什么是集合,什么是子集? 比较粗犷的讲法,集合就是一堆确定的东西,细致一点的讲 ...

  3. [python语法]python中如何判断一个集合是另一个集合的子集?

    问:python中如何判断一个集合是另一个集合的子集? 答:用issubset()方法 语法: A.issubset(B) 返回: True 如果A是B的子集. False 如果A不是B的子集. 样例 ...

  4. 59-python基础-python3-集合-集合常用方法-判断一个集合是否是另一个集合的子集-issubset()-issuperset()

    判断一个集合是否是另一个集合的子集-issubset()-issuperset() 1-issubset() s1.issubset(s) 判断s1是否是s的子集 2-issuperset() 与is ...

  5. UVA 11825 Hackers’ Crackdown(集合动态规划 子集枚举)

    Hackers’ Crackdown Miracle Corporations has a number of system services running in a distributed com ...

  6. 【状压DP】【UVA11825】 Hackers' Crackdown

    传送门 Description 你是一个hacker,侵入了一个有着n台计算机(编号为1.2.3....n)的网络.一共有n种服务,每台计算机都运行着所有服务.对于每台计算机,你都可以选择一项服务,终 ...

  7. LeetCode 78,面试常用小技巧,通过二进制获得所有子集

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode专题第47篇文章,我们一起来看下LeetCode的第78题Subsets(子集). 这题的官方难度是Medium,点赞 ...

  8. C#中判断一个集合是另外一个集合的子集

    有这样的两个集合: string[] bigArr = new string[] { "a", "b", "c" };string[] sm ...

  9. 78. Subsets(中等,集合的子集,经典问题 DFS)

    Given a set of distinct integers, nums, return all possible subsets. Note: The solution set must not ...

随机推荐

  1. ORACLE将查询的多条语句拼在一个字段下

    select listagg(字段名,'分隔符') within group (order by 某个字段)

  2. android下的异步任务

    异步任务一般用在加载一些网络资源的时候用,主要的实现方法是新建一个类来继承AsyncTask这个父类,然后复写该类下面的一些方法,其中doInBackground方法是必须要的,下面看代码 packa ...

  3. ssm(Spring、Springmvc、Mybatis)实战之淘淘商城-第八天(非原创)

    文章大纲 一.课程介绍二.Solr基本介绍三.ssm整合Solr四.项目源码与资料下载五.参考文章   一.课程介绍 一共14天课程(1)第一天:电商行业的背景.淘淘商城的介绍.搭建项目工程.Svn的 ...

  4. 数据库(JDBC、DBUtils)

     JDBC(Java DataBase Connection) 今日内容介绍 u SQL语句查询 u JDBC 第1章 JDBC 1.1 JDBC概述 JDBC(Java Data Base Conn ...

  5. web开发模式小结:页面乱码和跳转

    本文由付老师总结书写 java开发模式: (1)第一种开始模式:javaBean+jsp : 优点:可以为web程序在jsp中减少java代码量 适用于该开发模式的jsp的动作元素:<jsp:u ...

  6. Ubuntu 16.04 开启休眠功能

    因为休眠功能在部分计算机无法正常工作,所以Ubuntu默认是不开启休眠功能. 要想开启休眠功能先进行如下测试: 1.先检查是否有交换分区(swap),如果有确认交换分区至少和实际可用内存一样大. 2. ...

  7. 避免使用 JS 特性 with(obj){}

    1)简要说明         with 语句可以方便地用来引用某个特定对象中已有的属性,但是不能用来给对象添加属性.要给对象创建新的属性,必须明确地引用该对象. 2)语法格式  with(object ...

  8. Java Web报错:getOutputStream() has already been called for this response解决方案

    今天做了个导出excel表的功能.大概代码如下: ouputStream = response.getOutputStream(); wb.write(ouputStream); ouputStrea ...

  9. Jquery-EasyUI combobox下拉框使用

    制作一个json文件: <input data-options="url:'${pageContext.request.contextPath }/json/combobox_data ...

  10. C# StreamReader对象

    1.读取文件 输入流用于从外部源读取数据,在很多情况下,数据源可以是磁盘上的文件或网络的某些位置,任何可能发送数据的位置都可以是数据源,比如网络应用程序,web服务,甚至是控制台.StreamRead ...