http://acm.hdu.edu.cn/showproblem.php?pid=1565

方格取数(1)

Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 4740    Accepted Submission(s): 1798

Problem Description
给你一个n*n的格子的棋盘,每个格子里面有一个非负数。 从中取出若干个数,使得任意的两个数所在的格子没有公共边,就是说所取的数所在的2个格子不能相邻,并且取出的数的和最大。
 
Input
包括多个测试实例,每个测试实例包括一个整数n 和n*n个非负数(n<=20)
 
Output
对于每个测试实例,输出可能取得的最大的和
 
Sample Input
3
75 15 21
75 15 28
34 70 5
 
Sample Output
188
  1. //dp[i][j]=max(dp[i-1][k]+curline); 其中(k & j ==0)
  2. //设dp[i][j]为取完前i行数中 第i行为二进制j状态的最大值
  3. #include<iostream>
  4. #include<cstdio>
  5. #include<cstring>
  6. using namespace std;
  7. int n,bit[1<<21];//存储合法状态
  8. int dp[2][1<<21];//滚动数组01之间转变。
  9. int top,m,map[21][21];
  10. void init()
  11. {
  12. int i,t=0;
  13. //得到符合题意的状态数 例如: 1011 & 10110(既1011 <<1 ) =1 可得1011不符合题意
  14. //state[]存储每一种合法状态
  15. for(i=0;i<top;i++)
  16. {
  17. if(i&(i<<1))
  18. continue;
  19. else
  20. {
  21. bit[t++]=i;
  22. }
  23. }
  24. }
  25. int getsum(int i,int x)//状态为x
  26. {
  27. int sum=0,t=0;
  28. while(x)
  29. {
  30. if(x&1)
  31. sum+=map[i][t];
  32. x=x>>1;
  33. t++;
  34. }
  35. return sum;
  36. }
  37. int main()
  38. {
  39. int i,j,k,max,x;
  40. while(~scanf("%d",&n))
  41. {
  42. m=1<<n;
  43.  
  44. top=1<<21;
  45. init();
  46. memset(dp,-1,sizeof(dp));
  47. for(i=0;i<n;i++)
  48. for(j=0;j<n;j++)
  49. scanf("%d",&map[i][j]);
  50. for(i=0;bit[i]<m;i++)
  51. dp[0][i]=getsum(0,bit[i]);//对第1行进行初始化
  52. for(i=1;i<n;i++) //遍历剩余数组
  53. {
  54. for(j=0;bit[j]<m;j++)//遍历所有状态
  55. {
  56. max=-9999;
  57. for(k=0;bit[k]<m;k++)
  58. { //(i+1)&1无论怎么取都是0,1;
  59. if(dp[(i+1)&1][k]!=-1&&(!(bit[j]&bit[k])))//保证上下不取。
  60. {//遍历上一层的所有状态,求出最大值。
  61. x=dp[(i+1)&1][k];
  62. if(max<x)
  63. max=x;
  64. }
  65. }
  66. dp[i&1][j]=max+getsum(i,bit[j]);
  67. }
  68. }
  69. max=-9999;
  70. i--;
  71. for(k=0;bit[k]<m;k++)
  72. {
  73. if(dp[i&1][k] >max)
  74. max = dp[i&1][k];
  75. }//遍历最后一行, 找最大值
  76. printf("%d\n",max);
  77.  
  78. }
  79. return 0;
  80. }
  81. /*
  82. 3
  83. 75 15 21
  84. 75 15 28
  85. 34 70 5
  86. */
 

HDU-1565 方格取数(1)的更多相关文章

  1. 网络流(最大流) HDU 1565 方格取数(1) HDU 1569 方格取数(2)

      HDU 1565 方格取数(1) 给你一个n*n的格子的棋盘,每个格子里面有一个非负数.从中取出若干个数,使得任意的两个数所在的格子没有公共边,就是说所取的数所在的2个格子不能相邻,并且取出的数的 ...

  2. HDU 1565 方格取数(1) 轮廓线dp

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1565 方格取数(1) Time Limit: 10000/5000 MS (Java/Others) ...

  3. HDU 1565 - 方格取数(1) - [状压DP][网络流 - 最大点权独立集和最小点权覆盖集]

    题目链接:https://cn.vjudge.net/problem/HDU-1565 Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32 ...

  4. hdu 1565 方格取数(1) 状态压缩dp

    方格取数(1) Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  5. hdu 1565 方格取数(1)(状态压缩dp)

    方格取数(1)                                                                 Time Limit: 10000/5000 MS (J ...

  6. HDU 1565 方格取数(1)(最大点权独立集)

    http://acm.hdu.edu.cn/showproblem.php?pid=1565 题意: 给你一个n*n的格子的棋盘,每个格子里面有一个非负数. 从中取出若干个数,使得任意的两个数所在的格 ...

  7. HDU 1565 方格取数(简单状态压缩DP)

    http://acm.hdu.edu.cn/showproblem.php?pid=1565 对于每一个数,取或者不取,用0表示不取,1表示取,那么对于每一行的状态,就可以用一个二进制的数来表示.比如 ...

  8. hdu - 1565 方格取数(1) && 1569 方格取数(2) (最大点权独立集)

    http://acm.hdu.edu.cn/showproblem.php?pid=1565 两道题只是数据范围不同,都是求的最大点权独立集. 我们可以把下标之和为奇数的分成一个集合,把下标之和为偶数 ...

  9. HDU 1565 方格取数 状压dp

    题目: 给你一个n*n的格子的棋盘,每个格子里面有一个非负数. 从中取出若干个数,使得任意的两个数所在的格子没有公共边,就是说所取的数所在的2个格子不能相邻,并且取出的数的和最大. Input 包括多 ...

  10. HDU 1565 方格取数(1) ——插头DP

    [题目分析] 其实直接状压就可以了. 但是有点闲,又写了一个可读性极差,智商低下,很(gou)好(pi)的代码 [代码] #include <cstdio> #include <cs ...

随机推荐

  1. rabbitmq pika connection closed

    You are here: Home / rabbitmq pika connection closed rabbitmq pika connection closed By lijiejie on  ...

  2. mysql复习笔记

    阅读目录 1.什么是SQL语句2.使用sql语句创建数据库和表3.创建数据表4.数据完整性约束5.四中基本字符类型说明6.SQL基本语句7.类型转换函数8.日期函数9.数学函数10.字符串函数11.联 ...

  3. 知识点摸清 - - position属性值之relative与absolute

    两者共同特点是: 改变文档流 激活元素left.top.right.bottom.z-index属性 让元素”浮起来“,z-index>0 不同的是: 1.position:relative 会 ...

  4. Unity3D 常用事件

    这里总结一下U3D常用的一些事件 //按下事件,GetKeyDown //抬起事件,Input.GetKeyUp //长按事件,Input.GetKey //任意键按下事件,Input.anyKeyD ...

  5. string.Join和Reverse的简单使用示例

    String.Join 方法 (String, String[]) 串联字符串数组的所有元素,其中在每个元素之间使用指定的分隔符. 例如,如果 separator 为“,”且 value 的元素为“a ...

  6. 关于“SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问 ”

    原因:在从远程服务器复制数据到本地时出现“SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatas ...

  7. Objective-C总Runtime的那点事儿(一)消息机制【转】

    RunTime简称运行时.就是系统在运行的时候的一些机制,其中最主要的是消息机制.对于C语言,函数的调用在编译的时候会决定调用哪个函数( C语言的函数调用请看这里 ).编译完成之后直接顺序执行,无任何 ...

  8. 对数据预处理的一点理解[ZZ]

    数据预处理没有统一的标准,只能说是根据不同类型的分析数据和业务需求,在对数据特性做了充分的理解之后,再选择相关的数据预处理技术,一般会用到多种预处理技术,而且对每种处理之后的效果做些分析对比,这里面经 ...

  9. vlc_input buffer管理 & 时钟同步(转)

    vlc_input buffer管理 & 时钟同步 一.背景1.当播放网络视频流时(比如udp视频流),发送方(编码)和接收方(解码)是并行操作的,如果发送太慢(或因为网络原因出现延迟)的话, ...

  10. JSP中用include标签动态引入其它文件报错

    <jsp:include page="<%=path %>/include.jsp"></jsp:include> 报错:attribute f ...