description

在N行M列的棋盘上,放若干个炮可以是0个,使得没有任何一个炮可以攻击另一个炮。请问有多少种放置方法?中国象棋中炮的行走方式大家应该很清楚吧.


analysis

  • \(DP\),容易知道每行至多有两个炮,否则会互相打到

  • 设\(f[i][j][k]\)表示到放到第\(i\)行,有\(j\)列放了一个炮,\(k\)列放了两个炮的方案数

  • 该行不放炮,则直接继承上一行的答案

\[f[i][j][k]+=f[i-1][j][k]
\]

  • 一个炮放在没有炮的列上,一个炮的列数\(+1\),且有\(m-k-(j-1)\)个没有炮的列可以放

\[f[i][j][k]+=f[i-1][j-1][k]*[m-k-(j-1)]
\]

  • 一个炮放在一个炮的列上,一个炮的列数\(-1\),两个炮的列数\(+1\),且有\(j+1\)个一个炮的列可以放

\[f[i][j][k]+=f[i-1][j+1][k-1]*(j+1)
\]

  • 一个炮放在一个炮的列上,一个炮放在没有炮的列上,两个炮的列数\(+1\),且分别有\(j\)列、\(m-(k-1)-j\)列可以放

\[f[i][j][k]+=f[i-1][j][k-1]*j*[m-(k-1)-j]
\]

  • 两个炮放在没有炮的列上,一个炮的列数\(+2\),且有\(C^{2}_{m-(j-2)-k}\)种方案

\[f[i][j][k]+=f[i-1][j-2][k]*C^{2}_{m-(j-2)-k}
\]

  • 两个炮放在一个炮的列上,一个炮的列数\(-2\),两个炮的列数\(+2\),且有\(C^{2}_{j+2}\)种方案

\[f[i][j][k]+=f[i-1][j+2][k-2]*C^{2}_{j+2}
\]

  • 如此转移即可,注意判断边界

code

#pragma GCC optimize("O3")
#pragma G++ optimize("O3")
#include<stdio.h>
#include<string.h>
#include<algorithm>
#define MAXN 105
#define ha 9999973
#define ll long long
#define reg register ll
#define fo(i,a,b) for (reg i=a;i<=b;++i)
#define fd(i,a,b) for (reg i=a;i>=b;--i) using namespace std; ll f[MAXN][MAXN][MAXN];
ll c[MAXN][MAXN];
ll n,m,ans; inline ll read()
{
ll x=0,f=1;char ch=getchar();
while (ch<'0' || '9'<ch){if (ch=='-')f=-1;ch=getchar();}
while ('0'<=ch && ch<='9')x=x*10+ch-'0',ch=getchar();
return x*f;
}
inline ll C(ll n){return n*(n-1)/2;}
int main()
{
n=read(),m=read(),f[0][0][0]=1;
fo(i,1,n)
{
fo(j,0,m)
{
fo(k,0,m-j)
{
f[i][j][k]=f[i-1][j][k];//不填
if (k-1>=0)
(f[i][j][k]+=f[i-1][j+1][k-1]*(j+1)%ha)%=ha;//一颗填一个炮的列
if (j-1>=0)
(f[i][j][k]+=f[i-1][j-1][k]*(m-(j-1)-k))%=ha;//一颗填没有炮的列
if (k-1>=0)
(f[i][j][k]+=f[i-1][j][k-1]*j%ha*(m-j-(k-1)))%=ha;//一颗填一个炮的列,一颗填没有炮的列
if (j-2>=0)
(f[i][j][k]+=f[i-1][j-2][k]*C(m-(j-2)-k))%=ha;//两颗填没有炮的列
if (k-2>=0)
(f[i][j][k]+=f[i-1][j+2][k-2]*C(j+2))%=ha;//两颗填一个炮的列
}
}
}
fo(i,0,m)fo(j,0,m-i)(ans+=f[n][i][j])%=ha;
printf("%lld\n",ans);
return 0;
}

【JZOJ1667】【BZOJ1801】【luoguP2051】中国象棋的更多相关文章

  1. bzoj1801 [Ahoi2009]中国象棋

    Description 在N行M列的棋盘上,放若干个炮可以是0个,使得没有任何一个炮可以攻击另一个炮. 请问有多少种放置方法,中国像棋中炮的行走方式大家应该很清楚吧. Input 一行包含两个整数N, ...

  2. [BZOJ1801][AHOI2009]中国象棋(递推)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1801 分析: 只会50的状态压缩…… 然后搜了下题解,发现是dp 首先易得每行每列至多 ...

  3. 【BZOJ1801】【AHOI2009】中国象棋(动态规划)

    [BZOJ1801][AHOI2009]中国象棋(动态规划) 题面 题目描述 这次小可可想解决的难题和中国象棋有关,在一个N行M列的棋盘上,让你放若干个炮(可以是0个),使得没有一个炮可以攻击到另一个 ...

  4. 【BZOJ1801】[Ahoi2009]chess 中国象棋 DP

    [BZOJ1801][Ahoi2009]chess 中国象棋 Description 在N行M列的棋盘上,放若干个炮可以是0个,使得没有任何一个炮可以攻击另一个炮. 请问有多少种放置方法,中国像棋中炮 ...

  5. BZOJ1801 Ahoi2009 chess 中国象棋 【DP+组合计数】*

    BZOJ1801 Ahoi2009 chess 中国象棋 Description 在N行M列的棋盘上,放若干个炮可以是0个,使得没有任何一个炮可以攻击另一个炮. 请问有多少种放置方法,中国像棋中炮的行 ...

  6. [luogu2051][bzoj1801][AHOI2009]chess中国象棋【动态规划】

    题目描述 这次小可可想解决的难题和中国象棋有关,在一个N行M列的棋盘上,让你放若干个炮(可以是0个),使得没有一个炮可以攻击到另一个炮,请问有多少种放置方法.大家肯定很清楚,在中国象棋中炮的行走方式是 ...

  7. BZOJ1801:[AHOI2009]中国象棋——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=1801 https://www.luogu.org/problemnew/show/P2051 这次小 ...

  8. [AHOI2009]中国象棋 BZOJ1801 dp

    题目描述 这次小可可想解决的难题和中国象棋有关,在一个N行M列的棋盘上,让你放若干个炮(可以是0个),使得没有一个炮可以攻击到另一个炮,请问有多少种放置方法.大家肯定很清楚,在中国象棋中炮的行走方式是 ...

  9. BZOJ1801 [Ahoi2009]chess 中国象棋(DP, 计数)

    题目链接 [Ahoi2009]chess 中国象棋 设$f[i][j][k]$为前i行,$j$列放了1个棋子,$k$列放了2个棋子的方案数 分6种情况讨论,依次状态转移. #include <b ...

随机推荐

  1. zabbix--zabbix server的配置以及zabbix agent的安装配置

    1.zabbix  server端的配置在进行源码安装zabbix时已经配置好了,具体要配置的参数如下: ListenPort=10051 server服务的监听端口,默认是10051 DBHost= ...

  2. 如果通过cookies和localStorage取值?

    1. getCook : 设定setCookie值 let setCookie = setCookie('wan',data,7); function setCookie(c_name,value,e ...

  3. ArcGis拓扑——规则、概念与要点

    在地理数据库中,拓扑是定义点要素.线要素以及面要素共享重叠几何的方式的排列布置.例如,街道中心线与人口普查区块共享公共几何,相邻的土壤面共享公共边界. 处理拓扑不仅仅是提供一个数据存储机制.在 Arc ...

  4. Mac OS X终端的常用操作命令(UNIX指令)

    用了十多年windows,终于换了个高配Mac,俗话说 无论前端还是后端最终还是走向了linux,无论是换了多少台PC最终都会走向Mac.不学习命令行用什么Mac? 干就完了~ pwd 显示现在的文件 ...

  5. Red5流媒体服务器开发

    Red5流媒体服务器开发总结 Red5 是 支持Windows,Linux等多平台的RTMP流媒体服务器,最早属于谷歌下的开源项目,先已移植到Github,地址为https://github.com/ ...

  6. lambda和DynamoDB连接

    在DynamoDB当作创建一个新表,然后在项目当中创建,把string value的值填写一下. 在IAM创建角色附加 AWSLambdaDynamoDBExecutionRole权限 在lambda ...

  7. kubeadm部署一个Kubernetes集群

    kubeadm是官方社区推出的一个用于快速部署kubernetes集群的工具.这个工具能通过两条指令完成一个kubernetes集群的部署: # 创建一个 Master 节点 $ kubeadm in ...

  8. dubbo入门之异步调用

    dubbo默认使用同步的方式调用.但在有些特殊的场景下,我们可能希望异步调用dubbo接口,从而避免不必要的等待时间,这时候我们就需要用到异步.那么dubbo的异步是如何实现的呢?下面就来看看这个问题 ...

  9. Download QT

    http://download.qt.io/archive/qt/

  10. Android中的SrollView滚动详解

    今天开发遇到一个需求就是ScrollView中嵌套一个ListView,同时需要实现滑动到底部自动加载更多,我们知道ListView滑动到底部简单实现onScrollListener()监听器即可,但 ...