洛谷 - P2051 - 中国象棋 - 简单dp
2024-10-15 05:52:42
https://www.luogu.org/problemnew/show/P2051
一点都不简单的简单dp。
还是从旧行转移到新行,而不是考虑新行从哪些旧行转移吧。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
namespace combinatorics{
const ll MOD=9999973;
//1. 快速幂 x^n %mod
inline ll qpow(ll x,ll n,ll mod=MOD) {
ll res=1%mod;
while(n) {
if(n&1)
res=res*x%mod;
x=x*x%mod;
n>>=1;
}
return res;
}
//3. 乘法逆元 快速幂+费马小定理,要求p必须是质数 (依赖1. 快速幂)
inline ll inv_p(ll n,ll p=MOD) {
return qpow(n,p-2,p);
}
};
using namespace combinatorics;
//注意需要init(),必要时修改常量
ll dp[101][101][101]={};
//前i行中,j列放了1个,k列放了2个的方法数
int main(){
int n,m;
scanf("%d%d",&n,&m);
ll inv2=inv_p(2,MOD);
dp[1][0][0]=1;
//不放也是一种方法
dp[1][1][0]=m;
//只有1列放了1个
if(m>=2)
dp[1][2][0]=(ll)m*(m-1)%MOD*inv2%MOD;
//只有2列放了1个
for(int i=1;i<n;i++){
for(int j=0;j<=m;j++){
for(int k=0;k<=m-j;k++){
//这一行不放
dp[i+1][j][k]=(dp[i+1][j][k]+dp[i][j][k])%MOD;
int v=m-j-k;
//放一个在空列,有v种放法
if(v-1>=0&&j+1<=m)
dp[i+1][j+1][k]=(dp[i+1][j+1][k]+dp[i][j][k]*v)%MOD;
//放一个在原本有1个的列,有j种方法
if(j-1>=0&&k+1<=m)
dp[i+1][j-1][k+1]=(dp[i+1][j-1][k+1]+dp[i][j][k]*j)%MOD;
//放两个,两个都在空列
if(v-2>=0&&j+2<=m)
dp[i+1][j+2][k]=(dp[i+1][j+2][k]+dp[i][j][k]*(v)*(v-1)*inv2)%MOD;
//放两个,两个都在原本有1个的列
if(j-2>=0&&k+2<=m)
dp[i+1][j-2][k+2]=(dp[i+1][j-2][k+2]+dp[i][j][k]*(j)*(j-1)*inv2)%MOD;
//放两个,一个在空列,一个在原本有1个的列
if(v-1>=0&&k+1<=m)
dp[i+1][j][k+1]=(dp[i+1][j][k+1]+dp[i][j][k]*v*j)%MOD;
//printf("dp[%d][%d][%d]=%lld\n",i,j,k,dp[i%2][j][k]);
}
}
}
//puts("");
ll ans=0;
for(int j=0;j<=m;j++){
for(int k=0;k<=m-j;k++){
ans=(ans+dp[n][j][k])%MOD;
//printf("dp[%d][%d][%d]=%lld\n",n,j,k,dp[n%2][j][k]);
}
}
printf("%lld\n",ans);
}
最新文章
- LeetCode-9-Palindrome Number
- JavaScript 回忆录
- 【HDU 4940】Destroy Transportation system(无源无汇带上下界可行流)
- 演示一个VPD进行数据访问控制的示例
- WCF服务部署IIS
- linux 错误处理
- windows 下安装Yii2 高级版本
- 关键词:ACM &; 大小端 &; 面试官
- MVC中Model,不仅仅只是数据的传递者
- TCL 双引号和花括号的区别
- jdbc - Insert &#39;Date&#39; value in PreparedStatement
- Pomelo的监控模块
- Threads(线程)(二)
- c++STL(栈、队列)
- 玩转PS路径,轻松画logo!
- 用CSS写气泡
- python 面向对象(五)约束 异常处理 MD5 日志处理
- Contest2073 - 湖南多校对抗赛(2015.04.06)
- 控件布局_RelativeLayout
- jquery实现点击展开列表同时隐藏其他列表 js 对象操作 对象原型操作 把一个对象A赋值给另一个对象B 并且对象B 修改 不会影响 A对象
热门文章
- 深入理解Java:注解(Annotation)自定义注解入门(转载)
- android android:duplicateParentState=&;quot;true&;quot; &;quot;false&;quot;
- three supported reliability levels: * End-to-end * Store on failure * Best effort
- java XML-RPC
- redis一些笔记
- codeforces 463A Caisa and Sugar 解题报告
- hdu Integer Inquiry 解题报告
- fiddler_test
- poj图论解题报告索引
- blog.codedream.ren