题目描述

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

输入格式:

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

输出格式:

所得的方案数

输入样例

3 2

输出样例

16


题(mang)目(mu)分析:

爆裂吧!!!五重循环!!!!

我们用三维数组dp[i][j][l]

表示前i行共放了l个king

且第i行状态为j的方案数

先把只考虑一行的合法方案枚举出来存入state[]数组

同时预处理dp[1][][]的所有情况

  1. void check(ll x)
  2. {
  3. //将状态x分别左/右移判断是否有相邻的king
  4. if( !(x & (x<<1) ) && !(x & (x>>1) ) )
  5. {
  6. ll num=get(x);//计算该状态有多少个king
  7. if(num>k) return;//若num>k,则不合法
  8. else state[++cnt]=x,sum[cnt]=num,dp[1][x][num]=1;
  9. //储存该状态,并更新dp数组
  10. }
  11. }

对于0<= x <= (1<< n)-1都要调用

接下来状态转移方程

dp[i][j][l]+=dp[i-1][t][p]

  1. for(int i=2;i<=n;i++)//第1行已预处理,所以从第二行开始递推
  2. for(int j=1;j<=cnt;j++)//枚举第2行状态
  3. for(int l=0;l<=k;l++)//枚举前i行所放king数量
  4. for(int t=1;t<=cnt;t++)//枚举i-1行状态
  5. for(int p=0;p<=l;p++)//枚举前i-1行所放king数量
  6. if( test(state[j],state[t]) && p+sum[j]==l )//判断是否合法
  7. dp[i][state[j]][l]+=dp[i-1][state[t]][p];//更新

最后ans等于所有dp[n][j][k]相加


  1. #include<iostream>
  2. #include<vector>
  3. #include<algorithm>
  4. #include<queue>
  5. #include<cstring>
  6. #include<cstdio>
  7. using namespace std;
  8. typedef long long ll;
  9. ll n,k;
  10. ll state[1010];
  11. ll sum[1010];
  12. ll dp[10][1010][100];
  13. ll cnt;
  14. ll ans;
  15. ll get(ll x)
  16. {
  17. ll num=0;
  18. while(x>0)
  19. {
  20. if(x&1) num++;
  21. x=x>>1;
  22. }
  23. return num;
  24. }
  25. void check(ll x)
  26. {
  27. if( !(x & (x<<1) ) && !(x & (x>>1) ) )
  28. {
  29. ll num=get(x);
  30. if(num>k) return;
  31. else state[++cnt]=x,sum[cnt]=num,dp[1][x][num]=1;
  32. }
  33. }
  34. bool test(ll x,ll y)
  35. {
  36. if(x&y) return false;
  37. if((x<<1)&y) return false;
  38. if((x>>1)&y) return false;
  39. return true;
  40. }
  41. int main()
  42. {
  43. cin>>n>>k;
  44. for(int i=0;i<=(1<<n)-1;i++)
  45. check(i);
  46. for(int i=2;i<=n;i++)
  47. for(int j=1;j<=cnt;j++)
  48. for(int l=0;l<=k;l++)
  49. for(int t=1;t<=cnt;t++)
  50. for(int p=0;p<=l;p++)
  51. if( test(state[j],state[t]) && p+sum[j]==l )
  52. dp[i][state[j]][l]+=dp[i-1][state[t]][p];
  53. for(int i=1;i<=cnt;i++)
  54. ans+=dp[n][state[i]][k];
  55. cout<<ans;
  56. return 0;
  57. }

洛谷P1896 [SCOI2005]互不侵犯King【状压DP】的更多相关文章

  1. 【题解】洛谷P1896 [SCOI2005] 互不侵犯(状压DP)

    洛谷P1896:https://www.luogu.org/problemnew/show/P1896 前言 这是一道状压DP的经典题 原来已经做过了 但是快要NOIP 复习一波 关于一些位运算的知识 ...

  2. 洛谷P1896 [SCOI2005]互不侵犯King

    P1896 [SCOI2005]互不侵犯King 题目描述 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共 ...

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

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

  4. 【BZOJ1087】 [SCOI2005]互不侵犯King 状压DP

    经典状压DP. f[i][j][k]=sum(f[i-1][j-cnt[k]][k]); cnt[i]放置情况为i时的国王数量 前I行放置情况为k时国王数量为J #include <iostre ...

  5. [BZOJ1087] [SCOI2005] 互不侵犯King (状压dp)

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

  6. 洛谷 P1896 [SCOI2005]互不侵犯 (状态压缩DP)

    题目描述 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子. 注:数据有加强(2018/4/25) ...

  7. 洛谷 P1896 [SCOI2005]互不侵犯King

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

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

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

  9. 洛谷 P1896 [SCOI2005]互不侵犯

    洛谷 P1896 [SCOI2005]互不侵犯 题目描述 在N×N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8 ...

随机推荐

  1. 话说TP框架里的Vendor这目录是干什么用的啊?类库扩展thinkphp3.1版本

    类库扩展包括基类库扩展.应用类库扩展和第三方类库扩展,所有扩展类库不会自动加载,需要手动加载或者定义别名和配置自动加载(详细可以参考4.2.3类库导入和4.2.5自动加载). 1 基类库扩展 目前支持 ...

  2. dedecms_

    2012-7-5(no1)当我们点击检索结果的某个电影超链接时,如何跳转到对应的内容页[本资源由www.qinglongweb.com搜集整理] dedelist标签 --可以嵌套 项目移植: mys ...

  3. CC2650LaunchPad 运行contiki hello-world示例程序

    最近做毕设,开始接触contiki. 下载并运行Instant Contiki 3.0 这是官方制作的虚拟机镜像,直接用vmware等工具就可以运行. 从这里下载. 下载并解压后,用vmware运行. ...

  4. 数据库复习总结(20)-存储过程以及.net调用存储过程

    一.存储过程(注意区分将一段select语句进行封装叫做视图)(1)将一段t-sql脚本进行封装,以完成一个逻辑操作(2)创建存储过程:            create proc 名称      ...

  5. 【jsp】MyEclipse10.7.1最新版+破解下载

    MyEclipse企业级工作平台[1](MyEclipse Enterprise Workbench ,简称MyEclipse)是对EclipseIDE的扩展,利用它我们可以在数据库和JavaEE的开 ...

  6. .net Core学习笔记2 实现列表的条件筛选,排序,分页

    打开vs,完善上次"简单粗暴"的项目 发现上次的实体类的导航属性有点问题,这是更改后的 namespace ProductMvc.Models { public class Pro ...

  7. ORACLE约束总结

    你对ORACLE约束的了解如何?比较模糊还是相当透彻?如果你对下面几个问题了如指掌的话,恭喜你,你已经对约束掌握得比较好了,不用看这篇文章了.ORACLE的约束有啥功能作用? 有哪些类型约束(不同版本 ...

  8. ulua c#调用lua中模拟的类成员函数

    项目使用ulua,我神烦这个东西.lua单纯在lua环境使用还好,一旦要跟外界交互,各种月经不调就来了.要记住贼多的细节,你才能稍微处理好.一个破栈,pop来push去,位置一会在-1,一会在-3,2 ...

  9. java基础(一) 深入解析基本类型

    .   浮点数使用 IEEE(电气和电子工程师协会)格式. 浮点数类型使用 符号位.指数.有效位数(尾数)来表示.要注意一下,尾数的最高 在java中,float 和 double 的结构如下: 类 ...

  10. TensorflowTutorial_二维数据构造简单CNN

    使用二维数据构造简单卷积神经网络 觉得有用的话,欢迎一起讨论相互学习~Follow Me 图像和一些时序数据集都可以用二维数据的形式表现,我们此次使用随机分布的二位数据构造一个简单的CNN-网络卷积- ...