题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1711

题目大意:给定一个正整数n,产生一个3*n位长的串,要求这个串中(1)A、B、C的数目都是n;(2)这个串的任意一个前缀,也就是从开始往后任意一段连续序列中字符的个数A>=B>=C。求满足条件的数目。

Sample Input

  1. 2
  2.  
  3. 3

Sample Output

  1. 5
  2.  
  3. 42

分析:令dp[i][j][k]  表示从第一个字符开始,长度为i+j+k的串,A的个数为 i ,B的个数为 j ,C的个数为 k 的字符串的个数。

  则如果i>=j>=k  则可以根据最后一个字符是A, B还是C,分三类计数,假设是最后一位是A,由于题目的要求是前缀 ,所以前面的放法数恰好是dp[i-1][j][k]

  另外两种情况同理,加的时候注意下标小于零就不要了,答案为dp[n][n][n]

  后来发现是高精度,需要再加一维dp[i][j][k][p],最后一维是该数字的大数表示。

  这样如果dp数组用int类型表示,会超内存。后来改用short类型,内存36000险过,用char类型也是可以过的。short型理论上用输出%hd的,不过%d也可以。

代码如下:

  1. # include<iostream>
  2. # include<cstdio>
  3. # include<cstring>
  4. using namespace std;
  5.  
  6. short dp[][][][];
  7. void init()
  8. {
  9. short i,j,k,p,temp;
  10. memset(dp,,sizeof(dp));
  11. dp[][][][] = ;
  12. for(i=; i<=; i++)
  13. for(j=i; j<=; j++)
  14. for(k=j; k<=; k++)
  15. {
  16. if(i>) //dp[i][j][k] += dp[i-1][j][k];
  17. {
  18. temp = ;
  19. for(p=; p<=; p++)
  20. {
  21. dp[i][j][k][p] += dp[i-][j][k][p] + temp;
  22. if(dp[i][j][k][p]>)
  23. {
  24. temp = ;
  25. dp[i][j][k][p] -= ;
  26. }
  27. else
  28. temp = ;
  29. }
  30. }
  31. if(j>) //dp[i][j][k] += dp[i][j-1][k];
  32. {
  33. temp = ;
  34. for(p=; p<=; p++)
  35. {
  36. dp[i][j][k][p] += dp[i][j-][k][p] + temp;
  37. if(dp[i][j][k][p]>)
  38. {
  39. temp = ;
  40. dp[i][j][k][p] -= ;
  41. }
  42. else
  43. temp = ;
  44. }
  45. }
  46. if(k>) //dp[i][j][k] += dp[i][j][k-1];
  47. {
  48. temp = ;
  49. for(p=; p<=; p++)
  50. {
  51. dp[i][j][k][p] += dp[i][j][k-][p] + temp;
  52. if(dp[i][j][k][p]>)
  53. {
  54. temp = ;
  55. dp[i][j][k][p] -= ;
  56. }
  57. else
  58. temp = ;
  59. }
  60. }
  61. }
  62. }
  63.  
  64. int main()
  65. {
  66. init();
  67. int n;
  68. while(scanf("%d",&n)!=EOF)
  69. {
  70. int i;
  71. for(i=; i>=; i--)
  72. if(dp[n][n][n][i] != ) break;
  73. for(; i>=; i--) //输出高精度数
  74. printf("%d",dp[n][n][n][i]);
  75. printf("\n\n");
  76. }
  77. return ;
  78. }

POJ 2711 Regular Words(DP + 高精度)的更多相关文章

  1. HDU 1502 Regular Words DP+高精度

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1502 题目大意:找出总的满足条件的字符串数,num(a)=num(b)=num(c)且任何前缀均满足n ...

  2. poj 1205 :Water Treatment Plants (DP+高精度)

    题意:有n个城市,它们由一个污水处理系统连接着,每个城市可以选择 1.将左边城市过来的污水和右边城市过来的污水连同本身的污水排到河里  >V< 2.将左边来的污水连同自己的污水排到右边   ...

  3. 1166 矩阵取数游戏[区间dp+高精度]

    1166 矩阵取数游戏 2007年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description [ ...

  4. bzoj 1089 [SCOI2003]严格n元树(DP+高精度)

    1089: [SCOI2003]严格n元树 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1250  Solved: 621[Submit][Statu ...

  5. POJ 2711 Leapin' Lizards / HDU 2732 Leapin' Lizards / BZOJ 1066 [SCOI2007]蜥蜴(网络流,最大流)

    POJ 2711 Leapin' Lizards / HDU 2732 Leapin' Lizards / BZOJ 1066 [SCOI2007]蜥蜴(网络流,最大流) Description Yo ...

  6. CF23 E. Tree 树形dp+高精度

    题目链接 CF23 E. Tree 题解 CF竟让卡常QAQ dp+高精度 dp[x][j]表示以x为根的子树,x所属的联通块大小为j,的最大乘积(不带j这块 最后f[x]维护以x为根的子树的最大答案 ...

  7. POJ.3624 Charm Bracelet(DP 01背包)

    POJ.3624 Charm Bracelet(DP 01背包) 题意分析 裸01背包 代码总览 #include <iostream> #include <cstdio> # ...

  8. 【bzoj2764】[JLOI2011]基因补全 dp+高精度

    题目描述 在生物课中我们学过,碱基组成了DNA(脱氧核糖核酸),他们分别可以用大写字母A,C,T,G表示,其中A总与T配对,C总与G配对.两个碱基序列能相互匹配,当且仅当它们等长,并且任意相同位置的碱 ...

  9. DP+高精度 URAL 1036 Lucky Tickets

    题目传送门 /* 题意:转换就是求n位数字,总和为s/2的方案数 DP+高精度:状态转移方程:dp[cur^1][k+j] = dp[cur^1][k+j] + dp[cur][k]; 高精度直接拿J ...

随机推荐

  1. UltraISO PE(软碟通) v9.6.2.3059 注册码

    注册码: 王涛7C81-1689-4046-626F

  2. POJ2478 - Farey Sequence(法雷级数&&欧拉函数)

    题目大意 直接看原文吧.... The Farey Sequence Fn for any integer n with n >= 2 is the set of irreducible rat ...

  3. 最简单的基于FFMPEG的音频编码器(PCM编码为AAC)

    http://blog.csdn.net/leixiaohua1020/article/details/25430449 本文介绍一个最简单的基于FFMPEG的音频编码器.该编码器实现了PCM音频采样 ...

  4. 用Quartus II 建立一个工程模板,以后新建工程时无需再配置参数

    以前用Quartus II 每次新建工程时,都要设置工程名,选择工程路径,选择芯片型号等等,好麻烦呀!可不可以建一个工程模板,以后新建工程时直接改相应文件名就可以呀!后来我一琢磨,感觉也不是不可以.因 ...

  5. void,extern,sizeof

    高手潜规则:禁用goto 程序质量与goto出现次数成反比 void指针的意义 1.C语言规定只有相同类型的指针才可以相互赋值 2.void*指针作为坐值用于"接收"任意类型的指针 ...

  6. java web 自定义错误页面 完整jsp错误页面代码(同时写错误日志) error.jsp

    1.首先配置web.xml  添加一下代码 <error-page> <error-code>500</error-code> <location>/e ...

  7. JAVA基础入门

    Java入门基础 1.IDE->Eclipse 新建程序步骤 1.创建一个Java项目 2.创建一个包(package) 也就相当于C#中的命名空间C++中的头文件 3.创建一个类 这样就完成了 ...

  8. YUV422蓝屏显示输出功能辅助调试

    YUV422蓝屏显示输出功能辅助调试 YUV422有YUYV,YVYU,UYVY,VYUY四种,以下笔者就就以UYVY为例介绍一下数据构成.因为常常要跟视频输入打交道,所以YUV422这种常见的视频信 ...

  9. Could not initialize class org.apache.log4j.LogManager 报错

    部署项目的时候,在windows下一切正常,但是在centos下就发生如下错误 Caused by: java.lang.ExceptionInInitializerError at com.dsid ...

  10. MVC - 模型验证

    使用MVC的数据验证特性可以自动实现客户端验证和服务端验证 假设有一个Employee类 public class Employee { public int ID { get; set; } pub ...