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),到达一个城市要一定的花费,可以在城市工作赚钱,但前提有工作证(得到有一定的花费),没工作证不能在该城市工作,但可以走, ...
随机推荐
- 事件模型的介绍与Button的ActionListener
事件监听: 这是个很重要的概念,也是个很重要的模型,vb,vc都是这样用,甚至后面学的web框架也在用. 现在我们可以做很多按钮了吧,但是我们的按钮按它是没反应的,现在我们来看看怎么样才能让它有 ...
- Katalon Studio 安装 配置 简单使用
本教程只针对Katalon Studio进行演示操作. 一.下载 Katalon 官网下载地址:https://www.katalon.com/download/ (需要注册账号) 二.解压.配置 直 ...
- 【原创】DESTOON做中英双语言(多语言)切换版本具体详解
第一次发原创好激动,该注意点什么? 在开发过程中用户有许多要求,比如这个多语言切换就是一个需求. 首先讲解一下DESTOON(DT)后台系统如何做这个中英.甚至多语言切换的这个功能. DT本身不自带多 ...
- js 零散知识
# 同一种类型的事件注册多个事件句柄,后面的不会覆盖前面的事件 # event.which == 13,13代表回车 # parsley.js验证框架 # JSON.stringify, avoid ...
- hibernate 5.x版本中中schemaexport的使用
public static void main(String[] args) { /*//创建hibernate配置对象 Configuration cfg = new Configuration() ...
- iOS工具】rvm、Ruby环境和CocoaPods安装使用及相关报错问题解决
〇.前言 <p>在iOS开发中 CocoaPods作为库依赖管理工具就是一把利器. 有了 CocoaPods则无需再通过拖 第三方库及第三方库所依赖的 framework静态库到项目中等麻 ...
- ORACLE IN 与NOT IN 的性能区别
业务问题大概可以这样描述,一个父表,一个子表,查询的结果是找到子表中没有使用父表id的记录,这种情况估计很多系统都会牵涉得到.让我们来举一个例子: 表一: 父表 parent 表二: 子表 child ...
- C++中const与constexpr区别
对于对象来说 const指的是编译期常量和运行时常量,两者并没有区分 constexpr特指编译期常量 对于函数来说 const可以修饰类的成员函数,被修饰的函数在执行期间不会改变对象的值. clas ...
- [Python3网络爬虫开发实战] 3.1.1-发送请求
使用urllib的request模块,我们可以方便地实现请求的发送并得到响应,本节就来看下它的具体用法. 1. urlopen() urllib.request模块提供了最基本的构造HTTP请求的方法 ...
- Ubuntu 系统安装(这里用ubuntu 16.04)
一.安装Vmware Workstation 12 选择新建虚拟机- 下一步-安装根据红框部分及说明一步一步进行 点击下一步进行 接下来默认下一步,直到如下图 这里的最大磁盘大小100G.不会直接在本 ...