Problem Description
There is an old country and the king fell in love with a devil. The devil always asks the king to do some crazy things. Although the king used to be wise and beloved by his people. Now he is just like a boy in love and can’t refuse any request from the devil. Also, this devil is looking like a very cute Loli.

After the ring has been destroyed, the devil doesn't feel angry, and she is attracted by z*p's wisdom and handsomeness. So she wants to find z*p out.

But what she only knows is one part of z*p's DNA sequence S leaving on the broken ring.

Let us denote one man's DNA sequence as a string consist of letters from ACGT. The similarity of two string S and T is the maximum common subsequence of them, denote by LCS(S,T).

After some days, the devil finds that. The kingdom's people's DNA sequence is pairwise different, and each is of length m. And there are 4^m people in the kingdom.

Then the devil wants to know, for each 0 <= i <= |S|, how many people in this kingdom having DNA sequence T such that LCS(S,T) = i.

You only to tell her the result modulo 10^9+7.

 
Input
The first line contains an integer T, denoting the number of the test cases.
For each test case, the first line contains a string S. the second line contains an integer m.

T<=5
|S|<=15. m<= 1000.

 
Output
For each case, output the results for i=0,1,...,|S|, each on a single line.
 
题目大意:字符集中只有“ATCG”四种字符,现在给你一个字符串S。问长度为m的所有字符串T中,最长公共子序列lcs(S, T) = i,其中 i 取遍0~|S|。|S|为S的长度。
思路:令state = lcs(S, T),其中state为lcs在S中的位置的信息再状态压缩后的值。总之这是一个状态压缩DP。
如果用dp[i][state]来表示lcs(S, T[1..i])的T[1..i]的数量,那么计算出来的结果会有重复导致无法得出正确的结果。
定义newlcs(S, T) = lcs(S, T)的最小的state。
举个栗子:S = AATTCCGG
那么对于T = ATCG
newlcs(S, T) = pos[0, 2, 4, 6],有且只有这一个解(从0开始计数)
这样,用dp[i][state]来表示newlcs(S, T[1..i])的T[1..i]的数量。那么对于每个T[1..i],有且只有一个dp[i][state]和它对应,其中state = newlca(S, T[1..i])。
那么就可以花O(2^n*n*4)的时间来预处理出每个state加上一个字符得到的新state。
再花O(m*2^n*4)的时间用滚动数组做状态压缩DP。
再统计一下答案,解决。
PS:代码里面__builtin_popcount()是G++内置函数,用于求一个数的二进制中1的个数。
 
代码(1281MS):
  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. #include <algorithm>
  5. using namespace std;
  6.  
  7. const int MAXN = ;
  8. const int MOD = 1e9 + ;
  9.  
  10. char dic[] = "ACTG";
  11. int add[ << ][];
  12. int dp[][ << ];
  13. int pre[MAXN], lcs[MAXN], ans[MAXN];
  14. char s[MAXN];
  15. int T, n, m;
  16.  
  17. inline void update_add(int &a, int b) {
  18. a += b;
  19. if(a >= MOD) a -= MOD;
  20. }
  21.  
  22. void init() {
  23. for(int state = ; state < ( << n); ++state) {
  24. pre[] = ;
  25. for(int i = ; i <= n; ++i) pre[i] = pre[i - ] + ((state >> (i - )) & );
  26. for(int k = ; k < ; ++k) {
  27. for(int i = ; i <= n; ++i) {
  28. if(s[i] == dic[k]) lcs[i] = pre[i - ] + ;
  29. else lcs[i] = max(lcs[i - ], pre[i]);
  30. }
  31. int &t = add[state][k] = ;
  32. for(int i = ; i <= n; ++i)
  33. t |= ((lcs[i] != lcs[i - ]) << (i - ));
  34. }
  35. }
  36. }
  37.  
  38. void solve() {
  39. int *now = dp[], *next = dp[];
  40. memset(next, , ( << n) * sizeof(int));
  41. next[] = ;
  42. for(int _ = ; _ < m; ++_) {
  43. swap(now, next);
  44. memset(next, , ( << n) * sizeof(int));
  45. for(int state = ; state < ( << n); ++state) if(now[state])
  46. for(int k = ; k < ; ++k)
  47. update_add(next[add[state][k]], now[state]);
  48. }
  49. memset(ans, , sizeof(ans));
  50. for(int state = ; state < ( << n); ++state) {
  51. update_add(ans[__builtin_popcount(state)], next[state]);
  52. }
  53. for(int i = ; i <= n; ++i)
  54. printf("%d\n", ans[i]);
  55. }
  56.  
  57. int main() {
  58. scanf("%d", &T);
  59. while(T--) {
  60. scanf("%s%d", s + , &m);
  61. n = strlen(s + );
  62. init();
  63. solve();
  64. }
  65. }

HDU 4899 Hero meet devil(状压DP)(2014 Multi-University Training Contest 4)的更多相关文章

  1. HDU 4899 Hero meet devil (状压DP, DP预处理)

    题意:给你一个基因序列s(只有A,T,C,G四个字符,假设长度为n),问长度为m的基因序列s1中与给定的基因序列LCS是0,1......n的有多少个? 思路:最直接的方法是暴力枚举长度为m的串,然后 ...

  2. BZOJ 3864 Hero meet devil (状压DP)

    最近写状压写的有点多,什么LIS,LCSLIS,LCSLIS,LCS全都用状压写了-这道题就是一道状压LCSLCSLCS 题意 给出一个长度为n(n<=15)n(n<=15)n(n< ...

  3. hdu 4899 Hero meet devil

    传送阵:http://acm.hdu.edu.cn/showproblem.php?pid=4899 题目大意:给定一个DNA序列,求有多少长度为m的序列与该序列的最长公共子序列长度为0,1...|S ...

  4. HDU 6149 Valley Numer II 状压DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6149 题意:中文题目 解法:状压DP,dp[i][j]代表前i个低点,当前高点状态为j的方案数,然后枚 ...

  5. HDU 5434 Peace small elephant 状压dp+矩阵快速幂

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5434 Peace small elephant  Accepts: 38  Submissions: ...

  6. HDU 1074 Doing Homework(状压DP)

    第一次写博客ORZ…… http://acm.split.hdu.edu.cn/showproblem.php?pid=1074 http://acm.hdu.edu.cn/showproblem.p ...

  7. HDU 4906 Our happy ending (状压DP)

    HDU 4906 Our happy ending pid=4906" style="">题目链接 题意:给定n个数字,每一个数字能够是0-l,要选当中一些数字.然 ...

  8. HDU 1074 Doing Homework (状压dp)

    题意:给你N(<=15)个作业,每个作业有最晚提交时间与需要做的时间,每次只能做一个作业,每个作业超出最晚提交时间一天扣一分 求出扣的最小分数,并输出做作业的顺序.如果有多个最小分数一样的话,则 ...

  9. HDU 4568 Hunter 最短路+状压DP

    题意:给一个n*m的格子,格子中有一些数,如果是正整数则为到此格子的花费,如果为-1表示此格子不可到,现在给k个宝藏的地点(k<=13),求一个人从边界外一点进入整个棋盘,然后拿走所有能拿走的宝 ...

随机推荐

  1. VB的判断语句和循环语句

      判断语句 •If语句 if语句共有4种写法: 第一种语法: If 条件判断语句 then 程序代码 第二种语法:If 条件判断语句 then 程序代码 else 程式代码 第三种语法: If 条件 ...

  2. IOS 手势事件的冲突

    关于手操作需要强调几点: UIImageView默认是不支持交互的,也就是userInteractionEnabled=NO ,因此要接收触摸事件(手势识别),必须设置userInteractionE ...

  3. ASP.NET MVC4中用 BundleCollection使用问题手记

    ASP.NET MVC4中对JS和CSS的引用又做了一次变化,在MVC3中我们这样引用资源文件: <link href="@Url.Content("~/Content/Si ...

  4. json的eval为什么要用msg.d

    在做一个关于搜索功能时用到了jquery autocomplete,发现返回数据时都用到了一个.d,比如: var datas = eval('(' + msg.d + ')'); 这个.d是什么呢, ...

  5. Selenium2学习-026-WebUI自动化实战实例-024-获取页面元素

    非常简单的方法封装,就不啰嗦了,直接上码咯 ^_^ /** * Get element. It will be return null when there is not such element. ...

  6. 关于action script与js相互调用的Security Error问题

    大家都知道,as和js相互调用可以通过ExternalInterface.call和ExternalInterface.addCallback来进行. 比较好的做法是使用之前通过ExternalInt ...

  7. Given a binary tree containing digits from0-9only, each root-to-leaf path could represent a number. An example is the root-to-leaf path1->2->3which represents the number123. Find the total sum of a

    class TreeNode { int val; TreeNode left; TreeNode right; TreeNode(int x) { val = x; } } public class ...

  8. iOS 使用XCode6打开项目以后再用XCode5出现的问题fatal error: malformed or corrupted AST file: 'Unable to load module

    使用不同版本的XCode出现的问题: fatal error: malformed or corrupted AST file: 'Unable to load module "/Users ...

  9. 淘宝杨志丰:OceanBase--淘宝结构化大数据解决之道

    时至今日,“Big data”(大数据)时代的来临已经毋庸置疑,尤其是在电信.金融等行业,几乎已经到了“数据就是业务本身”的地步.这种趋势已经让很多相信数据之力量的企业做出改变.恰逢此时,为了让更多的 ...

  10. Chrome控制台调试工具用法

    下面我们来看看console里面具体提供了哪些方法可以供我们平时调试时使用. Console API 当打开 firebug (也包括 Chrome 等浏览器的自带调试工具),window 下面会注册 ...