原题链接:填数字

顺便推荐一下,偶然看到这个OJ,发现社区运营做得很赞,而且交互和编译环境都很赞(可以编译包括Python,Ruby,Js在内的脚本语言,也可以编译新标准的C/C++11,甚至包括Go和C Sharp等),虽然暂时不太火,但估计会逐渐成为国内算法界非常受欢迎的OJ社区。

主页:http://www.51nod.com/index.html


  

  本题是个题意简单的,思路复杂的DP题,说实话,光是想出这种DP就已经非常不易了,即便写出来也要考虑清楚每一种转移的公式和数值关系。

  

  原题:有n(1-200)行格子,第i(1<=i<=n)行有i个格子,每行格子是左对齐。现在要在每一个格子填入一个非负整数,最后使得每一行每一列的和都不超过2。

     请计算有多少种方案,答案比较大,请输出对100,000,007(1e8+7)取余后的结果。

     下图是n=4的时候格子的摆放。

      

 //务必注意理清每次状态转移方程的思路和公式
//博主因为一个地方写多了个+1,结果WA了5发....
//Memory:34900K Time:93Ms
#include<iostream>
using namespace std; #define MAX 201
#define MOD 100000007 #define COL_0 (i - j - k - 1) //和为0的列数
/*
* dp[i][j][k]
* i:表明当前行
* j:表明i行完成时有多少列为1
* k:表明j行完成时有多少列为2
* dp值表明该状态下的情况数
* 每次由 i-1行 -> i行 转移同j同k的状态
*/
__int64 dp[MAX][MAX][MAX]; int main()
{
int n;
scanf("%d", &n);
dp[][][] = dp[][][] = dp[][][] = ;
for (__int64 i = ; i <= n; i++)
for (__int64 j = ; j <= i; j++)
for (__int64 k = ; k <= i - j; k++)
{
//最后一格为0时
//-可+2
if (i - j - k - >= )
dp[i][j][k + ] = (dp[i][j][k + ] + dp[i - ][j][k] * COL_0) % MOD;
//-可+1
//--两个1_0-0
if (i - j - k - >= )
dp[i][j + ][k] = (dp[i][j + ][k] + dp[i - ][j][k] * (COL_0 * (COL_0 - ) / )) % MOD;
//--两个1_1-0
if (j >= && i - j - k - >= )
dp[i][j][k + ] = (dp[i][j][k + ] + dp[i - ][j][k] * COL_0 *j) % MOD;
//--两个1_1-1
if (j >= )
dp[i][j - ][k + ] = (dp[i][j - ][k + ] + dp[i - ][j][k] * (j*(j - ) / )) % MOD;
//--一个1_1
if (j >= )
dp[i][j - ][k + ] = (dp[i][j - ][k + ] + dp[i - ][j][k] * j) % MOD;
//--一个1_0
if (i - j - k - >= )
dp[i][j + ][k] = (dp[i][j + ][k] + dp[i - ][j][k] * COL_0) % MOD;
//什么都不加
dp[i][j][k] = (dp[i][j][k] + dp[i - ][j][k]) % MOD; //最后一格为1时
//-可+1_0
if (i - j - k - >= )
dp[i][j + ][k] = (dp[i][j + ][k] + dp[i - ][j][k] * COL_0) % MOD;
//-可+1_1
if (j >= )
dp[i][j][k + ] = (dp[i][j][k + ] + dp[i - ][j][k] * j) % MOD;
//什么都不加
dp[i][j + ][k] = (dp[i][j + ][k] + dp[i - ][j][k]) % MOD; //最后一格为2时
dp[i][j][k + ] = (dp[i][j][k + ] + dp[i - ][j][k]) % MOD;
} __int64 sum = ;
for (int j = ; j <= n; j++)
for (int k = ; k <= n - j; k++)
sum = (sum + dp[n][j][k]) % MOD;
printf("%I64d\n", sum); return ;
}

ACM/ICPC 之 DP进阶(51Nod-1371(填数字))的更多相关文章

  1. 51NOD 1371填数字

    传送门 分析 此题关键在于想出dp[i][j][k]代表考虑到第i行,还能放1的的共有j列,还能放2的共有k行.之后就枚举每一行是没有还是1个1还是2个1还是1个2,然后转移即可. 代码 #inclu ...

  2. ACM/ICPC 之 DP解有规律的最短路问题(POJ3377)

    //POJ3377 //DP解法-解有规律的最短路问题 //Time:1157Ms Memory:12440K #include<iostream> #include<cstring ...

  3. 2016 ACM/ICPC Asia Regional Shenyang Online 1009/HDU 5900 区间dp

    QSC and Master Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  4. 2016 ACM/ICPC Asia Regional Shenyang Online 1007/HDU 5898 数位dp

    odd-even number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  5. HDU 5000 2014 ACM/ICPC Asia Regional Anshan Online DP

    Clone Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/65536K (Java/Other) Total Submiss ...

  6. 【转】lonekight@xmu·ACM/ICPC 回忆录

    转自:http://hi.baidu.com/ordeder/item/2a342a7fe7cb9e336dc37c89 2009年09月06日 星期日 21:55 初识ACM最早听说ACM/ICPC ...

  7. ACM ICPC Kharagpur Regional 2017

    ACM ICPC Kharagpur Regional 2017 A - Science Fair 题目描述:给定一个有\(n\)个点,\(m\)条无向边的图,其中某两个点记为\(S, T\),另外标 ...

  8. 2014嘉杰信息杯ACM/ICPC湖南程序设计邀请赛暨第六届湘潭市程序设计竞赛

    比赛链接: http://202.197.224.59/OnlineJudge2/index.php/Contest/problems/contest_id/36 题目来源: 2014嘉杰信息杯ACM ...

  9. 2016 ACM/ICPC亚洲区青岛站现场赛(部分题解)

    摘要 本文主要列举并求解了2016 ACM/ICPC亚洲区青岛站现场赛的部分真题,着重介绍了各个题目的解题思路,结合详细的AC代码,意在熟悉青岛赛区的出题策略,以备战2018青岛站现场赛. HDU 5 ...

随机推荐

  1. Jedis 例子(demo)大全

    第一步:到git下载jedis源码,如果你用maven或者gradle,那么直接下官方的即可,地址:https://github.com/xetorthio/jedis:如果你用ant,下载这个:ht ...

  2. nanosleep() -- 更精确的延迟 -----一个使用用例

    [常规] nanosleep() -- 更精确的延迟 [复制链接]     beyes 4220 主题 5152 帖子 3万 积分 GROAD 曲径通幽,安觅芳踪. 积分 30607 发消息 电梯直达 ...

  3. UML类图之类与类的关系

    类与类之间的关系是在需求分析阶段确定的. 类与类之间的关系.有一般化关系.关联关系.聚合关系.合成关系和依赖关系. 1.一般化关系表示类与类之间的继承关系,接口与接口之间的继承关系,或类对接口的实现关 ...

  4. linux网络:常用命令(一)

    1.ifconfig  可以查看Linux的网卡情况 ifconfig eth0 查看 eth0的信息 给一块网卡设置多个ip地址: ifconfig eth0:0 192.168.1.12 255. ...

  5. ZOJ3802 Easy 2048 Again (状压DP)

    ZOJ Monthly, August 2014 E题 ZOJ月赛 2014年8月 E题 http://acm.zju.edu.cn/onlinejudge/showProblem.do?proble ...

  6. No enclosing instance of type E is accessible. Must qualify the allocation with an enclosing

    在Java中,类中的静态方法不能直接调用动态方法.只有将某个内部类修饰为静态类,然后才能够在静态类中调用该类的成员变量与成员方法.所以在不做其他变动的情况下,最简单的解决办法是将public clas ...

  7. 软件测试-----Graph Coverage作业

    /******************************************************* * Finds and prints n prime integers * Jeff ...

  8. Android手机如何通过USB共享网络给Mac?

    最近网络挂了,mac不能上网查资料,心情非常毛躁,急切寻求用mac蹭WiFi的方法. 没有找到电脑端破解WiFi密码的软件,手头的Android手机没有root,也无法查看WiFi密码--->破 ...

  9. 网络编程3-URL编程(URL)

    1.URL(Uniform Resource Locatior) 统一资源占位符,表示Intenet上某一资源的地址 2.URL的组成部分 传输协议:主机名:端口号:文件名 例:http://192. ...

  10. JQuery在asp.net中三种ajax传值

    1)通过webservice,注意去掉注释[System.Web.Script.Services.ScriptService]这行前的注释 2)通过aspx.cs文件中的静态方法 3)通过aspx文件 ...