题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5389

大体题意是:有两个门A和B,还有一群人,每个人都有一个数字,

疯了一样的T。。比赛的时候十连T也是醉醉的。  

这道题感觉像DP,但是不知道从何下手,看别人敲出来才知道怎么去用。

在比赛过程中还有一个问题,想法对了,样例过了,但是T了

原因是因为数组开大了,在dp的过程中用了memset,导致T

在标程里,用了滚动数组,感觉很巧妙,因为dp只需要知道上一状态即可,

利用异或的性质,不断滚动0101010101

---------------------------------------关于digital的性质------------------------------------------------------------

当一群人各位数字之和等于门上数字的时候才可以通过门,可以只通过一个门也可以两个门都通过。

The digital root of a non-negative integer is the single digit value obtained by an iterative process of summing digits,

on each iteration using the result from the previous iteration to compute a digit sum. The process continues until

a single-digit number is reached.

关于digital root(以下用R表示),有以下几条性质:

1、9加(乘)任何数所得的和(积)的数字根,等于原数的数字根(9)

2、若A+B=C,则A,B的数字根(Ra Rb)的和的数字根为C的数字根(Rc)

3、若A*B=C,则A,B的数字根(Ra Rb)的积的数字根为C的数字根(Rc)

4、若A^n=B,则Ra^n的数字跟=Rb。

------------------DP思路---------------------

dp[i+1][a[i]+k] = dp[i+1][a[i]+k] + dp[i][k];

更新加了一个数之后的状态

dp[i+1][k] = dp[i+1][k] + dp[i][k];

加上上一状态的情况数

------------------分情况讨论-------------------

之后比较巧的是对于情况的讨论

1、如果数字跟不等于A+B且不等于A且不等于B,则情况数为0

2、如果是数字根等于A+B的数字根,那么情况数就等于dp[n][A] = dp[n][B]

3、如果数字根等于A或B,那么情况数只有一个

4、如果数字跟等于A且等于B,那么情况数有两个

具体代码如下

  1. )==sum);
  2. )ans=(ans+)%MOD;
  3. )ans=(ans+)%MOD;

注意到后两种情况其实可以合并,如果A=B的话,后两个if语句同时成立,ans = 2;

  1. #include<stdio.h>
  2. #include<cstring>
  3. #include<algorithm>
  4. #define rep(i,j,k) for(int i=(int)j;i<(int)k;i++)
  5. #define per(i,j,k) for(int i=(int)j;i>(int)k;i--)
  6. using namespace std;
  7. ;
  8. ;
  9. int T, n;
  10. int A, B;
  11. int a[MAXN];
  12. int now, sum, ans;
  13. ][];
  14. int main(){
  15. scanf("%d",&T);
  16. while(T--){
  17. scanf("%d",&n);
  18. scanf("%d %d",&A,&B);
  19. A %= ;B %= ;
  20. sum = ;
  21. rep(i,,n){
  22. scanf("%d",&a[i]);
  23. a[i] = a[i] % ;
  24. sum = (sum+a[i])%;
  25. }
  26. ) && sum != A && sum != B){
  27. puts(");
  28. continue;
  29. }
  30. memset(dp,,sizeof(dp));
  31. dp[][] = ;
  32. now = ;
  33. rep(i,,n){
  34. now ^= ;
  35. rep(k,,) dp[now][k] = ;
  36. rep(k,,){
  37. dp[now][(a[i]+k)%] = ( dp[now][(a[i]+k)%] + dp[now^][k])%MOD;
  38. dp[now][k] = ( dp[now][k] + dp[now^][k])%MOD;
  39. }
  40. }
  41. )==sum);
  42. )ans=(ans+)%MOD;
  43. )ans=(ans+)%MOD;
  44. printf("%d\n",ans);
  45. }
  46. }

hdoj 5389 Zero Escape的更多相关文章

  1. 递推DP HDOJ 5389 Zero Escape

    题目传送门 /* 题意:把N个数分成两组,一组加起来是A,一组加起来是B,1<=A,B<=9,也可以全分到同一组.其中加是按照他给的规则加,就是一位一位加,超过一位数了再拆分成一位一位加. ...

  2. HDU 5389 Zero Escape(dp啊 多校)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5389 Problem Description Zero Escape, is a visual no ...

  3. HDU 5389 Zero Escape(DP + 滚动数组)

    Zero Escape Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) To ...

  4. hdu 5389 Zero Escape(记忆化搜索)

    Problem Description Zero Escape, is a visual novel adventure video game directed by Kotaro Uchikoshi ...

  5. hdu 5389 Zero Escape (dp)

    题目:http://acm.hdu.edu.cn/showproblem.php? pid=5389 题意:定义数根:①把每一位上的数字加起来得到一个新的数,②反复①直到得到的数仅仅有1位.给定n,A ...

  6. 2015 Multi-University Training Contest 8 hdu 5389 Zero Escape

    Zero Escape Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Tot ...

  7. HDU 5389 Zero Escape (MUT#8 dp优化)

    [题目链接]:pid=5389">click here~~ [题目大意]: 题意: 给出n个人的id,有两个门,每一个门有一个标号,我们记作a和b,如今我们要将n个人分成两组,进入两个 ...

  8. HDU 5389 Zero Escape

    题意:有一些人,每人拿一个号码,有两个门,门的值分别为A和B,要求把人分成两堆(可以为空)一堆人手持号码之和的数字根若等于A或者B就可以进入A门或者B门,要求两堆人分别进入不同的门,求有几种分配方式, ...

  9. 【HDOJ】1813 Escape from Tetris

    bfs预处理一点到边界的最小距离,IDA*求出可行方案.注意按字典序初始化dir数组.并且存在中间点全为1,边界含0的可能性(wa了很多次).此时不输出任何命令. /* 1813 */ #includ ...

随机推荐

  1. HDU 5273 Dylans loves numbers(水题)

    题意:给出一个0≤N≤1018,求其二进制中有几处是具有1的,假设相连的1只算1处,比如1101011就是3处. 思路:一个个数,当遇到第一个1时就将flag置为1:当遇到0就将flag置为0.当遇到 ...

  2. 【英语】Bingo口语笔记(8) - 爆破音的发音技巧

    轻读,有时候甚至是听不到的,就嘴巴碰一下而已.

  3. Oracle 11g对大表中添加DEFAULT值的NOT NULL字段速度有大幅度的提升

    在一张2000万的表上增加了一个字段并字段一个默认值,执行这条语句(alter table tablename add new_col default ‘col’)一个小时没有执行完,问我有没有其他解 ...

  4. ACCESS中的窗体、报表、宏模块等(ACCESS 2000)

    窗体: 分为数据操作窗体,它包括单页.多页.连续.子窗口 控制窗体 信息交互窗体 窗体三种视图:“设计”视图.“窗体”视图.“数据表”视图 窗体建立的五种方式: 一:自动创建窗体 二:窗体向导(一对多 ...

  5. Android 网络流量监听开源项目-ConnectionClass源码分析

    很多App要做到极致的话,对网络状态的监听是很有必要的,比如在网络差的时候加载质量一般的小图,缩略图,在网络好的时候,加载高清大图,脸书的android 客户端就是这么做的, 当然伟大的脸书也把这部分 ...

  6. Scala下载安装配置(Mac)

    ---恢复内容开始--- 1.访问scala的官网这里下载最新版的scala. 2.解压缩文件包,可将其移动至/usr/local/share下 1 mv /download/scalapath /u ...

  7. App中嵌入网页浏览器

    TOWebViewController 插件 NSURL *url =[NSURL URLWithString:@"http://192.168.1.134:8180/Home/IndexP ...

  8. 输出流 写文件 文本 换行nextLine

      FileOutputStream   fos   =   new   FileOutputStream( "c:\\test.txt ");  String   nextLin ...

  9. 小结JS中的OOP(上)

    前言:大家都知道,OOP有三大特性:封装,继承,多态.下面是自己对这三个特性的理解: 封装:把属性与方法整合到某种数据类型中.目的是让类的使用者按类的编写者的意愿去使用类.在封装过程中会一般会做两件事 ...

  10. C# 导出一个控件的矢量图

    调用Control.DrawToBitmap(Bitmap) 方法是很容易得到控件的图形的. 但是bitmap是栅格化图形.栅格化图形有很多缺点,比如文件体积比较大. 放大后失真. 不易编辑等等. 这 ...