[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个格子 ...
随机推荐
- java键盘IO
public class IO { public static void main(String[] args) throws Throwable { ScannerTest(); // testSc ...
- TCP系列37—Keep Alive—1、TCP存活检测
一.TCP存活(keepalive)检测的背景 对于TCP设计来说,如果一个客户端和服务器端建立连接后,不在进行数据传输,那么这个连接将会一直存在下去,理论上即使中间的路由器崩溃重启.或者中间的网络线 ...
- git工具SourceTree工作流
分支模型 master 用来最终上线的分支,最终发布版本,整个项目中有且只有一个 develop 项目中用来开发的分支,原则上项目中有且只有一个,develop 分支下面的分支是经常变化的,会创建新的 ...
- 【Linux】linux中删除指定文件外所有其他文件(夹)的问题
今天碰到要删除指定文件(夹)外的其他文件的问题.网上查到的方法是这样的 需要在当前文件夹中进行: rm -rf !(keep) #删除keep文件之外的所有文件 rm -rf !(keep1|keep ...
- 【Python】python-内置常量
引言 Python的内置常量不多,只有6个,分别是True.False.None.NotImplemented.Ellipsis.__debug__ 一.True 1.True是bool类型用来表示的 ...
- BZOJ 2303 方格染色(带权并查集)
要使得每个2*2的矩形有奇数个红色,如果我们把红色记为1,蓝色记为0,那么我们得到了这2*2的矩形里的数字异或和为1. 对于每个方格则有a(i,j)^a(i-1,j)^a(i,j-1)^a(i-1,j ...
- BZOJ 1509 逃学的小孩(树的直径)
题意:从树上任找三点u,v,w.使得dis(u,v)+min(dis(u,w),dis(v,w))最大. 有一个结论u,v必是树上直径的两端点. 剩下的枚举w就行了. 具体不会证... # inclu ...
- 【转】c# 类反射简单操作
转:http://www.jb51.net/article/25863.htm 首先建立一个测试的类 复制代码代码如下: public class MyClass { public int one ...
- [洛谷P3833][SHOI2012]魔法树
题目大意:给一棵树,路径加,子树求和 题解:树剖 卡点:无 C++ Code: #include <cstdio> #include <iostream> #define ma ...
- Android ListView 显示多种数据类型
ListView往往可能会有不同的数据类型,单类型的数据可能运用会比较少些,这也是最近项目中的一个需求{在发送消息的时候,需要选择联系人,而联系人列表由英文字母索引+联系人组成},上一篇文章只是一个基 ...