HDU 2280 状压DP
用dfs找到状态的最优解
且那个正方形块可以由两个水平块组成,所以无需考虑
#include <cstdio>
#include <cstring>
#include <iostream> using namespace std;
#define N 1005
int state[N] , n , m , dp[N][<<]; void dfs(int i , int k , int state1 , int state2 , int v)
{
if(k > ){
dp[i][state2] = max(dp[i][state2] , v);
return;
}
if(k <= ){
if(!(state1&(<<k-)) && !(state2&(<<k-))){
dfs(i , k+ , state1 | (<<k-) , state2 | (<<k-) , v+);
}
if(!(state1&(<<k)) && !(state2&(<<k-))){
dfs(i , k+ , state1 | (<<k) , state2 | (<<k-) , v+);
}
if(!(state1&(<<k-)) && !(state2&(<<k-))){
dfs(i , k+ , state1 | (<<k-) , state2 | (<<k-) , v+);
}
if(!(state1&(<<k-)) && !(state2&(<<k))){
dfs(i , k+ , state1 | (<<k-) , state2 | (<<k) , v+);
}
if(!(state2&(<<k-))){
dfs(i , k+ , state1 , state2 | (<<k-) , v+);
}
}
else{
if(!(state1&(<<k-)) && !(state2&(<<k-))){
dfs(i , k+ , state1 | (<<k-) , state2 | (<<k-) , v+);
}
}
dfs(i , k+ , state1 , state2 , v);
} void dfs2(int k , int sta , int v)
{
if(k > ){
dp[][sta] = max(dp[][sta] , v);
return;
}
if(k <= ){
if(!(sta & (<<k-)))
dfs2(k+ , sta | (<<k-) , v+);
}
dfs2(k+ , sta , v);
} int main()
{
// freopen("a.in" , "rb" , stdin);
char a;
while(scanf("%d%d", &n , &m) != EOF){
memset(state , ,sizeof(state));
int all = ;
for(int i = ; i <= n ; i++)
for(int j=; j<= ; j++){
cin>>a;
if(a == ''){
state[i] |= (<<j-);
}
else all++;
} memset(dp , - , sizeof(dp));
dp[][state[]] = ;
dfs2( , state[] , ); for(int i= ; i <= n ; i++){
for(int j = ; j<(<<) ; j++){
if(dp[i-][j] >= ){
dfs(i , , j , state[i] , dp[i-][j]);
}
}
} int maxn = ; for(int i = ; i<(<<) ; i++){
maxn = max(maxn , dp[n][i]);
} int remain = all - maxn;
if(remain <= m) puts("YES");
else puts("NO");
}
return ;
}
HDU 2280 状压DP的更多相关文章
- HDU 4778 状压DP
一看就是状压,由于是类似博弈的游戏.游戏里的两人都是绝对聪明,那么先手的选择是能够确定最终局面的. 实际上是枚举最终局面情况,0代表是被Bob拿走的,1为Alice拿走的,当时Alice拿走且满足变换 ...
- HDU 3001 状压DP
有道状压题用了搜索被队友骂还能不能好好训练了,, hdu 3001 经典的状压dp 大概题意..有n个城市 m个道路 成了一个有向图.n<=10: 然后这个人想去旅行.有个超人开始可以把他扔到 ...
- hdu 2809(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2809 思路:简单的状压dp,看代码会更明白. #include<iostream> #in ...
- hdu 2167(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2167 思路:经典的状压dp题,前后,上下,对角8个位置不能取,状态压缩枚举即可所有情况,递推关系是为d ...
- Engineer Assignment HDU - 6006 状压dp
http://acm.split.hdu.edu.cn/showproblem.php?pid=6006 比赛的时候写了一个暴力,存暴力,过了,还46ms 那个暴力的思路是,预处理can[i][j]表 ...
- hdu 3254 (状压DP) Corn Fields
poj 3254 n乘m的矩阵,1表示这块区域可以放牛,0,表示不能,而且不能在相邻的(包括上下相邻)两个区域放牛,问有多少种放牛的方法,全部不放也是一种方法. 对于每块可以放牛的区域,有放或者不放两 ...
- HDU 5823 (状压dp)
Problem color II 题目大意 定义一个无向图的价值为给每个节点染色使得每条边连接的两个节点颜色不同的最少颜色数. 对于给定的一张由n个点组成的无向图,求该图的2^n-1张非空子图的价值. ...
- hdu 4739 状压DP
这里有状态压缩DP的好博文 题目:题目比较神,自己看题目吧 分析: 大概有两种思路: 1.dfs,判断正方形的话可以通过枚举对角线,大概每次减少4个三角形,加上一些小剪枝的话可以过. 2.状压DP,先 ...
- Travel(HDU 4284状压dp)
题意:给n个城市m条路的网图,pp在城市1有一定的钱,想游览这n个城市(包括1),到达一个城市要一定的花费,可以在城市工作赚钱,但前提有工作证(得到有一定的花费),没工作证不能在该城市工作,但可以走, ...
随机推荐
- 水题 Codeforces Round #306 (Div. 2) A. Two Substrings
题目传送门 /* 水题:遍历一边先找AB,再BA,再遍历一边先找BA,再AB,两种情况满足一种就YES */ #include <cstdio> #include <iostream ...
- [转]asp.net 跨域单点登录
本文转自:http://tech.e800.com.cn/articles/2009/814/1250212319986_1.html 单点登录(Single Sign On),简称为 SSO,是目前 ...
- 窗体WINFORM
窗体的事件:删除事件:先将事件页面里面的挂好的事件删除,再删后台代码里面的事件 Panel是一个容器 1.Label -- 文本显示工具Text:显示的文字取值.赋值:lable1.Text 2.Te ...
- spring实现模板文件下载
前台 <form id="batchModel0" method="post" action="/common/download-file&qu ...
- 【C++】模板简述(一):模板的引入
我们在介绍模板之前,首先想象有这么一个场景: 我们需要通过C++写出一个通用的加法程序,那么有如下几种方法: 方法一:C++的函数重载 //int int int int Add(int l,int ...
- Farseer.net轻量级开源框架说明及链接索引
Farseer.net是什么? 基于.net framework 4 开发的一系列解决方案. 完全开源在GitHub中托管.并发布到NuGet中. Farseer.Net由最初的关系数据库ORM框架后 ...
- Apache与IIS端口冲突解决方法
在安装Apache或者php集成环境包是经常会遇到Apache的80端口被占用导致无法正常启动Apache. Win7可以通过如下方法解决(如果坚持要使用80端口的话): 1.打开"控制面板 ...
- swift 与 @objc
Objective-C entry points https://github.com/apple/swift-evolution/blob/master/proposals/0160-objc-in ...
- cp - 复制文件和目录
总览 cp [选项] 文件路径 cp [选项] 文件...目录 POSIX 选项: [-fipRr] GNU 参数(最短形式): [-abdfilprsuvxPR] [-S SUFFIX] [-V { ...
- charset - 设置 G0/G1 字符集槽中的一个的 ACM
总览 (SYNOPSIS) charset [-v] G0|G1 [cp437|iso01|vt100|user|<acm_name>] 描述 (DESCRIPTION) linux 终端 ...