[BZOJ1087][SCOI2005]互不侵犯King解题报告|状压DP
在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案。国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子。
好像若干月前非常Naive地去写过DFS...
然后其实作为状压DP是一道非常好的题啦><
感觉直接无脑搞时间是下不来的 做了好几道预处理
使得最后DP的过程中没有任何一条转移是无用的
program bzoj1087;
var i,x,n,k,j,p,q,t1,t2:longint;
ans:int64;
a:array[-..]of longint;
b:array[-..,-..]of longint;
c:array[-..,-..]of longint;
f:array[..,-..,-..]of int64; function check(x:longint):boolean;
var las:longint;
begin
las:=;
while x<> do
begin
if (x and =)and(las=) then exit(false);
las:=x and ;
x:=x >> ;
end;
exit(true);
end; function count(x:longint):longint;
var tem:longint;
begin
tem:=;
while x<> do
begin
inc(tem,x and );
x:=x >> ;
end;
exit(tem);
end; function ok(x,y:longint):boolean;
var i:longint;
tmp:array[..,-..]of longint;
begin
for i:= downto do tmp[,i]:=x >> i and ;
for i:= downto do tmp[,i]:=y >> i and ;
for i:= to do if (tmp[,i]+tmp[,i]=)or(tmp[,i]+tmp[,i-]=)or(tmp[,i]+tmp[,i+]=) then exit(false);
exit(true);
end; begin
fillchar(b,sizeof(b),);
fillchar(a,sizeof(a),);
fillchar(c,sizeof(c),);
readln(n,k);
for i:= to << n- do if check(i) then
begin
x:=count(i);
inc(b[x,]);b[x,b[x,]]:=i;
inc(a[]);a[a[]]:=i;
end;
for i:= to a[] do
for j:= to a[] do if ok(a[i],a[j]) then begin inc(c[a[i],]);c[a[i],c[a[i],]]:=a[j];end;
fillchar(f,sizeof(f),);
for i:= to k do
for j:= to b[i,] do f[,i,b[i,j]]:=;
for i:= to n do
begin
f[]:=f[];
fillchar(f[],sizeof(f[]),);
for j:= to k do
for p:= to (n+) >> do if p<=j then
begin
q:=j-p;
for t1:= to b[p,] do
for t2:= to c[b[p,t1],] do inc(f[,j,b[p,t1]],f[,q,c[b[p,t1],t2]]);
end;
end;
ans:=;
for i:= to a[] do inc(ans,f[,k,a[i]]);
writeln(ans);
end.
[BZOJ1087][SCOI2005]互不侵犯King解题报告|状压DP的更多相关文章
- BZOJ1087 SCOI2005 互不侵犯King 【状压DP】
BZOJ1087 SCOI2005 互不侵犯King Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附 ...
- 状压入门--bzoj1087: [SCOI2005]互不侵犯King【状压dp】
Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上 左下右上右下八个方向上附近的各一个格子,共8个格子. Input 只有一行, ...
- [BZOJ1087] [SCOI2005] 互不侵犯King (状压dp)
Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子. Input 只有一行,包 ...
- bzoj1087: [SCOI2005]互不侵犯King (codevs2451) 状压dp
唔...今天学了状压就练练手... 点我看题 这题的话,我感觉算是入门题了QAQ... 然而我还是想了好久... 大致自己推出了方程,但是一直挂,调了很久选择了题解 坚持不懈的努力的调代码. 然后发现 ...
- [bzoj1087][scoi2005]互不侵犯king
题目大意 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上 左下右上右下八个方向上附近的各一个格子,共8个格子. 思路 首先,搜索可以放弃,因为这是一 ...
- BZOJ1087 [SCOI2005]互不侵犯King 状态压缩动态规划
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1087 题意概括 在n*n的棋盘上面放k个国王,使得他们互相无法攻击,问有多少种摆法. 题解 dp[ ...
- [BZOJ1076][SCOI2008]奖励关解题报告|状压DP
你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物,每次你都可以选择吃或者不吃(必须在抛出下一个宝物之前做出选择,且现在决定不吃的宝物以后也不能再吃). 宝 ...
- BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]
1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3336 Solved: 1936[Submit][ ...
- BZOJ 1087:[SCOI2005]互不侵犯King(状压DP)
[SCOI2005]互不侵犯King [题目描述] 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子 ...
随机推荐
- python爬虫从入门到放弃(四)之 Requests库的基本使用(转)
什么是Requests Requests是用python语言基于urllib编写的,采用的是Apache2 Licensed开源协议的HTTP库如果你看过上篇文章关于urllib库的使用,你会发现,其 ...
- 【APS.NET Core】- Json配置文件的读取
在项目目录下有个 appsettings.json ,我们先来操作这个文件.在appsettings.json中添加以下内容: { "Logging": { "LogLe ...
- VS2010中的sln,suo分别是什么含义
我们通过双击.sln加载出我们的工程. Visual Studio.NET采用两种文件类型(.sln和.suo)来存储特定于解决方案的设置,它们总称为解决方案文件.为解决方案资源管理器提供显示管理文件 ...
- Python自定义包在linux服务器导入错误的解决办法
在本地机器上跑python代码,自己定义的文件进行导包运行是没有问题,但是放到linux服务器上的时候就会提示 ImportError:No module named xxxx(要导入的文件包名) 在 ...
- dedecms给原模型添加新字段
1.进入dedecms后台 2.点击核心=>频道模型=>内容模型管理(在这里可以看到dedecms预设的模型设置) 3.选中我们需要的模型,点击更改,跳入以下页面 4.点击字段管理(可以看 ...
- linux tomcat shutdown.sh 不能正常关闭
一般造成这种原因是因为项目中有非守护线程的存在 基本原理为启动tomcat时记录启动tomcat的进程id(pid),关闭时强制杀死该进程 1.找到tomcat下bin/catalina.sh文件,v ...
- Spring MVC 之@Controller@RequestMapping详解
一:配置web.xml 1)问题:spring项目中有多个配置文件mvc.xml dao.xml 2)解决:在web.xml中 <init-param> <param-name& ...
- 【bzoj5107】[CodePlus2017]找爸爸 dp
题目描述 给出两个基因串,你需要在其中插入任意个空格,使得两个串长度相同.如果两个串的某同一位置都是字母则获得某给定收益,对于每个串的每个长度为k的连续空格段要付出a(k-1)+b的损失.求最大净收益 ...
- linux系统过一两分钟就断开的时间更改
vi /etc/ssh/sshd_config LoginGraceTime 参考man sshd_config LoginGraceTime The server disconnects after ...
- hdu 1142 A Walk Through the Forest (最短路径)
A Walk Through the Forest Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...