Time Limit: 10 Sec  Memory Limit: 162 MB

Submit: 3040  Solved: 1786

[Submit][Status][Discuss]

Description

  在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案。国王能攻击到它上下左右,以及左上

左下右上右下八个方向上附近的各一个格子,共8个格子。

Input

  只有一行,包含两个数N,K ( 1 <=N <=9, 0 <= K <= N * N)

Output

  方案数。

Sample Input

3 2

Sample Output

16

【题解】

设f[i][j][k]表示在第i行的放国王的序列为k,然后前i行放了j个国王的方案数;

f[i][j][k] = ∑[i-1][j-count[k]][pre_zhuangtai];

然后就是pre_zhuangtai 要怎么和k状态配对呢?

就是说你怎么知道这两行的国王不会发生冲突?

可以用dfs预处理出来。

然后用碉堡了的位运算来获取不合法的关系。剩下的就是合法的了。

1

1

1

01

01

10

像上面3个都是不合法的会发现

x<<1 x>>1 x 分别和y进行&运算。如果大于0.就是不合法的了。

记录下某两个状态是不是合法的就可以了。

【代码】

#include <cstdio>
#include <cstring> const int MAXN = 101; int n, k, n_zt = 0, zt[MAXN], count[MAXN];
long long f[10][101][101];
bool can[MAXN][MAXN]; void dfs(int num, int pre, int zhuangtai)
{
n_zt++;
zt[n_zt] = zhuangtai;
count[n_zt] = num;
if (num >= k)
return;
for (int i = pre + 2; i <= n; i++)
dfs(num + 1, i, zhuangtai + (1 << (i - 1)));
} int main()
{
//freopen("F:\\rush.txt", "r", stdin);
memset(can, true, sizeof(can));
scanf("%d%d", &n, &k);
dfs(0, -1, 0);
for (int i = 1; i <= n_zt; i++)
for (int j = 1; j <= n_zt; j++)
if ((zt[i] & zt[j]) || ((zt[i] << 1) & zt[j]) || ((zt[i] >> 1) & zt[j]))
can[j][i] = can[i][j] = false;
for (int i = 1; i <= n_zt; i++)
f[1][count[i]][i] = 1;
for (int i = 2;i <= n;i++)//枚举当前是第几行。
for (int j = 0;j <= k;j++)//枚举当总共放了多少个国王
for (int now = 1; now <= n_zt; now++)//枚举当前行的状态是什么
{
if (j < count[now])//如果枚举当前行状态的国王数目大于当前枚举的则跳过。
continue;
for (int prezt = 1; prezt <= n_zt; prezt++)//枚举前一行的状态是什么
if (can[prezt][now] && count[prezt] + count[now] <= j)
f[i][j][now] += f[i - 1][j - count[now]][prezt];
//如果这两行符合规则.且前一行的国王的数目加上这一行的国王的数目小于等于
//当前枚举的车的数目;
//这一行贡献了count[now]个国王。则前i-1行贡献了j-count[now]个国王.
}
long long ans = 0;
for (int i = 1; i <= n_zt; i++)
ans += f[n][k][i];
printf("%lld\n", ans);
return 0;
}

【58.75%】【BZOJ 1087】[SCOI2005]互不侵犯King的更多相关文章

  1. BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]

    1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3336  Solved: 1936[Submit][ ...

  2. bzoj 1087 [SCOI2005]互不侵犯King 状态压缩dp

    1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec  Memory Limit: 162 MB[Submit][Status][Discuss] Descripti ...

  3. bzoj[1087][SCOI2005]互不侵犯King

    Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子. Input 只有一行,包 ...

  4. bzoj 1087: [SCOI2005]互不侵犯King【状压dp】

    显然是状压,设f[i][j][k]为1到i行选j个king,并且第i行状态为k的方案数,判断是否可行然后枚举转移即可 先把可行状态预处理出来会变快 #include<iostream> # ...

  5. BZOJ 1087 [SCOI2005]互不侵犯King(状压DP)

    题意:在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子.n<=9 思路:状压dp,dp[i][ ...

  6. BZOJ 1087 [SCOI2005]互不侵犯King ——状压DP

    [题目分析] 沉迷水题,吃枣药丸. [代码] #include <cstdio> #include <cstring> #include <iostream> #i ...

  7. 1087: [SCOI2005]互不侵犯King

    1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4276  Solved: 2471[Submit][ ...

  8. 【BZOJ】1087: [SCOI2005]互不侵犯King(状压dp)

    http://www.lydsy.com:808/JudgeOnline/problem.php?id=1087 状压dp是第一次写啊,我也是才学TAT.状压dp一般都用一个值表示集合作为dp的一个状 ...

  9. 【BZOJ】1087: [SCOI2005]互不侵犯King

    [算法]状态压缩型DP [题解]http://www.cnblogs.com/xtx1999/p/4620227.html (orz) https://www.cnblogs.com/zbtrs/p/ ...

  10. 1087. [SCOI2005]互不侵犯King【状压DP】

    Description 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上 左下右上右下八个方向上附近的各一个格子,共8个格子. Input 只有一行, ...

随机推荐

  1. Directx11教程37 纹理映射(7)

    原文:Directx11教程37 纹理映射(7)     本章是在教程35.36的基础上来实现一个光照纹理结合的程序,就是把场景中旋转的cube加上纹理.    lighttex.vs中顶点的结构现在 ...

  2. iphone开发中使用nib(xib)文件的内存管理

    iphoneuinavigationcontrollercocoauiviewvariableswindows 在使用nib文件做界面开发的过程中,加载nib文件后,由于设置了outlet和deleg ...

  3. 【转】Sprague-Grundy函数

    http://www.cnitblog.com/weiweibbs/articles/42735.html 上一期的文章里我们仔细研究了Nim游戏,并且了解了找出必胜策略的方法.但如果把Nim的规则略 ...

  4. jquery on事件

    可以给后添加的动态元素绑定事件

  5. vue cli3 子目录问题

    在使用 vue-cli3 build的时候,使用非子目录需要在 vue.config.js 中添加如下代码: module.exports = { baseUrl: process.env.NODE_ ...

  6. cocos2d-x 特效集合

    本文转载自:http://www.cnblogs.com/linux-ios/archive/2013/04/09/3009292.html bool HelloWorld::init() { /// ...

  7. Jupyter Magic - Timing(%%time %time %timeit)

    对于计时有两个十分有用的魔法命令:%%time 和 %timeit. 如果你有些代码运行地十分缓慢,而你想确定是否问题出在这里,这两个命令将会非常方便. 1.%%time 将会给出cell的代码运行一 ...

  8. linux自动挂载NTFS格式移动硬盘

    转自:http://blog.163.com/cmh_lj/blog/static/100812304201252522119264/ 由于移动硬盘还有不少的资料,刚插入移动硬盘的时候发现只能自动挂载 ...

  9. oracle不明确的索引等级

    当ORACLE无法判断索引的等级高低差别,优化器将只使用一个索引,它就是在WHERE子句中被列在最前面的. 举例: DEPTNO上有一个非唯一性索引,EMP_CAT也有一个非唯一性索引. SELECT ...

  10. lualatex+Beamer生成ppt

    直接放模板代码 \documentclass{beamer} % There are many different themes available for Beamer. A comprehensi ...