hdu 4539(状压dp)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4539

思路:跟poj1185简直就是如出一辙!

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<algorithm>
 5 using namespace std;
 6 
 7 int row[111];
 8 int dp[111][222][222];
 9 int s[1<<12];
10 int num[1<<12];
11 int n,m,state,ans,x;
12 
13 int Get_Num(int x)
14 {
15     int cnt=0;
16     while(x>0){
17         cnt++;
18         x=x&(x-1);
19     }
20     return cnt;
21 }
22 
23 int main()
24 {
25     while(~scanf("%d%d",&n,&m)){
26         memset(row,0,sizeof(row));
27         memset(dp,0,sizeof(dp));
28         for(int i=0;i<n;i++){
29             for(int j=0;j<m;j++){
30                 scanf("%d",&x);
31                 if(!x)row[i]=(row[i]<<1)|1;
32                 else row[i]<<=1;
33             }
34         }
35         state=0;
36         for(int i=0;i<(1<<m);i++){
37             if(i&(i<<2))continue;
38             s[state]=i;
39             num[state++]=Get_Num(i);
40         }
41         for(int i=0;i<state;i++){
42             if(s[i]&row[0])continue;
43             dp[0][i][0]=num[i];
44         }
45         for(int i=1;i<n;i++){
46             for(int j=0;j<state;j++){
47                 if(s[j]&row[i])continue;
48                 for(int k=0;k<state;k++){  //i-1行信息
49                     if((s[j]&(s[k]>>1))||(s[j]&(s[k]<<1)))continue;//曼哈顿距离为2冲突
50                     for(int l=0;l<state;l++){  //i-2行信息
51                         if(s[j]&s[l])continue;
52                         if((s[k]&(s[l]>>1))||(s[k]&(s[l]<<1)))continue;//曼哈顿距离为2冲突
53                         dp[i][j][k]=max(dp[i][j][k],dp[i-1][k][l]+num[j]);
54                     }
55                 }
56             }
57         }
58         ans=0;
59         for(int i=0;i<state;i++){
60             for(int j=0;j<state;j++){
61                 ans=max(ans,dp[n-1][i][j]);
62             }
63         }
64         printf("%d\n",ans);
65     }
66     return 0;
67 }
View Code

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/292893.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

万字长文入门 Redis 命令、事务、锁、订阅、性能测试

Redis 基本数据类型Redis 中&#xff0c;常用的数据类型有以下几种&#xff1a;String&#xff1a;字符串类型&#xff0c;二进制安全字符串&#xff1b;Hash&#xff1a;哈希表&#xff1b;List 列表&#xff1a;链表结构&#xff0c;按照插入顺序排序的字符串元素的集合&…

postgresql 查看page, index, tuple 详细信息

下面的内容需要理解postgres术语 page, tuple, regclass, relname. sql command 需要用到 pgstattuple,pageinspect extension.Setup Extension create extension pgstatuplecreate extension pageinspect 查询page, index 详细信息 show how many pages in one tableselect pg…

python读写文件错误_Python读取csv文件错误解决方法

如果累了就拥抱我取暖 ——侃爷 今天这篇推文很简单&#xff0c;就是给大家总结一下我今天用pandas读取csv文件遇到的坑。 一直处理csv文件都是用pandas的read_csv函数读取csv文件之后处理&#xff0c;都没碰到过什么问题。But&#xff0c;But今天帮朋友处理csv文件时&#xff…

基于应用日志的扫描器检测实践

基于应用日志的扫描器检测实践 在网络上搜索web扫描器时&#xff0c;各类扫描器工具、扫描攻略玲琅满目&#xff0c;但对扫描器检测方法的内容却少之又少。因此&#xff0c;本文对各类web扫描特特征进行了梳理和总结&#xff0c;并结合苏宁应用防火墙&#xff08;SNWAF&#x…

shell基础三

如果表达式中包含特殊字符&#xff0c;Shell 将会进行替换。例如&#xff0c;在双引号中使用变量就是一种替换&#xff0c;转义字符也是一种替换。举个例子&#xff1a; #!/bin/basha10echo -e "Value of a is $a \n" 运行结果&#xff1a; Value of a is 10 这里 …

将一个压缩文件分成多个压缩文件;RAR文件分卷

有时候需要上传压缩文件&#xff0c;但是限制了单个文件的大小&#xff0c;那我们怎么才能将一个比较大的压缩文件分割成多个压缩文件&#xff0c;从而符合要求的进行文件的上传呢&#xff1f;这里小编告诉你一个技巧。 工具/原料 电脑 winrar&#xff08;一般电脑都自带了&…

定义命令别名(alias)

Linux之alias:1.查看当前别名&#xff1a;alias# alias alias cpcp -i alias l.ls -d .* --colortty alias llls -l --colortty alias lsls --colortty alias mvmv -i alias rmrm -i alias whichalias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde 2.设…

python画相关性可视化图_Python可视化很简单,一文教你绘制饼图、极线图和气泡图...

matplotlib库作为Python数据化可视化的最经典和最常用库&#xff0c;掌握了它就相当于学会了Python的数据化可视化&#xff0c;上次呢&#xff0c;已经和大家聊了关于柱状图、条形图和直方图相关的东东&#xff0c;相信大家已经掌握了哈&#xff0c;那今天呢&#xff0c;咱们再…

图像处理技术(二)滤波去噪

在图像处理领域中&#xff0c;在真正的应用过程前&#xff0c;通常需要对图像进行预先处理&#xff0c;达到去除干扰项的目的。滤波去噪就是其中的一项图像预处理工作。在.NET下常用OpenCV进行图像处理工作,常用的.NET下的OpenCV库有Emgu CV和OpenCVSharp。EmguCV是.NET平台下对…

iOS开发之Runtime关联属性

2019独角兽企业重金招聘Python工程师标准>>> 首先&#xff0c;推荐给大家一个非常好用的一个网站&#xff1a; 非盈利无广告开发者专用网址导航&#xff1a;http://www.dev666.com/ API介绍 我们先看看Runtime提供的关联API&#xff0c;只有这三个API&#xff0c;使…

shell基础四

Bash 支持很多运算符&#xff0c;包括算数运算符、关系运算符、布尔运算符、字符串运算符和文件测试运算符。原生bash不支持简单的数学运算&#xff0c;但是可以通过其他命令来实现&#xff0c;例如 awk 和 expr&#xff0c;expr 最常用。expr 是一款表达式计算工具&#xff0c…

DecisionTree决策树算法及参数详解+实例+graphviz生成决策树

DecisionTree决策树大全 原文&#xff1a;http://ihoge.cn/2018/DecisionTree.html 利用信息墒判定先对那个特征进行分裂 信息墒是衡量信息不确定性的指标&#xff0c;信息墒公式&#xff1a; H(X)−∑x∈XP(x)log2P(x)其中P(x)表示事件x出现的概率。回到决策树的构建问题上…

穿皮裤放屁,裤子会鼓吗?真相看这里!

1 拉莫斯&#xff1a;没事儿&#xff0c;打今儿起我管你叫哥&#xff0c;你管我叫爸&#xff0c;咱俩各论各的。▼2 妈妈都是为了你好▼3 秃头女孩最后的倔强▼4 新浪OS&#xff1a;呼~太紧张了&#xff0c;放松下▼5 这什么鬼玩意儿&#xff1f;▼6 这到底是爱老婆&…

公布一个软件,轻新视频录播程序,H264/AAC录制视音频,保存FLV,支持RTMP直播...

已经上传到CSDN&#xff0c;下载地址&#xff1a;http://download.csdn.net/detail/avsuper/7421647&#xff0c;不要钱滴&#xff0c;嘿嘿。。。 本程序能够把摄像头视频和麦克风音频&#xff0c;录制为FLV文件。 视频压缩採用H.264编码&#xff0c;音频压缩採用AAC编码&#…

linux共享库及/etc/ld.so.conf文件的应用

Linux 共享库 Linux 系统上有两类根本不同的 Linux 可执行程序。第一类是静态链接的可执行程序。静态可执行程序包含执行所需的所有函数 —换句话说&#xff0c;它们是“完整的”。因为这一原因&#xff0c;静态可执行程序不依赖任何外部库就可以运行。  第二类是动态链接的…

shell之a+b求和l脚本的三种写法

第一种 #!/bin/bash a5 b10 c$[ $a$b ] echo ${c}第二种 #!/bin/bash a5 b10 let "cab" echo ${c} 第三种 #!/bin/bash a5 b10 ((cab)) echo ${c}

如何判断一个程序是 32bit 还是 64bit ?

咨询区 Jonathan Allen我有一个 .NET 应用程序&#xff0c;我觉得它现在是 32bit&#xff0c;但又不确定构建服务器是否真的帮我编译成了 32bit&#xff0c;请问我有什么办法可以检测当前的程序是否是真的 32bit &#xff1f;回答区 Jaco Pretorius你想判断运行的应用程序是 32…

c语言知识点(1)

1、函数strlen()和关键字sizeof()sizeof()是运算符&#xff0c;返回值为unsign_int&#xff0c;参数可以是数组、指针、类型、对象、函数等。strlen()是函数&#xff0c;参数必须是字符型指针(char*)&#xff0c;2、strlen()/strcat()/strcmp()/strcpy 编写3、memset()/memcmp(…

史上最强物理科普

全世界只有3.14 % 的人关注了爆炸吧知识一沙见世界 一花窥天堂手心握无限 须臾纳永恒杨振宁曾说读上面的四句诗可以感受到物理的美但物理的美不止于此物理还有一种庄严美一种神秘美一种初窥宇宙奥秘的畏惧美物理就是如此的迷人任何语言在它的面前都很贫瘠数学让人摆脱了愚昧而…