先说HDU 4632这道题,因为比较简单,题意就是给你一个字符串,然后给你一个区间,叫你输出区间内所有的回文子序列,注意是回文子序列,不是回文字串。

用dp[i][j]表示区间[i,j]内的回文子序列的个数。

那么可以得到状态转移方程:dp[i][j] = dp[i + 1][j] + dp[i][j - 1] - dp[i + 1][j - 1] + a[i] == a[j] 。

#define N 1005
#define MOD 10007
int dp[N][N] ;
char a[N] ;
int main() {
int T ;
cin >> T ;
int cc = 0;
while( T -- ){
cin >> a ;
int l = strlen(a) ;
mem(dp ,0 ) ;
for (int i = 0 ; i < l ; i ++ )dp[i][i] = 1 ;
for (int i = 2 ; i <= l ; i ++ ){//枚举长度
for (int j = 0 ; j + i - 1 < l ; j ++ ){//枚举起点
int s = j ;
int e = j + i - 1 ;
if(a[s] == a[e])dp[s][e] ++ ;
else {
if(s + 1 <= e - 1){
dp[s][e] -= dp[s + 1][e - 1] ;
dp[s][e] = (dp[s][e] + MOD) % MOD ;
}
}
dp[s][e] += ( dp[s + 1][e] + dp[s][e - 1] ) % MOD ;
}
}
printf("Case %d: ",++cc) ;
cout << (dp[0][l - 1] + MOD ) % MOD << endl;
}
return 0 ;
}

CF 245H .这道题的题意差不多,不过他是给出区间,求出区间内的回文字串的个数。

上面那道题之所以我认为简单,是因为他不用判断[i , j ]之间是不是回文,因为他只需要计数就可以了。

而这道题,即使a[i] == a[j],也要判断[i + 1 , j - 1]之内是不是回文。

这里我是多开一个数组来存当前区间是否是回文,用isP[i][j]来判断这个区间是否是回文。

初始化isP[i][i] = 1 ,dp[i][i] = 1 ,因为他本身肯定是回文。

当然初始化的时候还要注意isP[i + 1][i] = 1 ,因为我们注意到,当枚举到长度为2的时候,我们假设字符串为aa 。

那么首先a[i] == a[j] .然后还要判断[i + 1, j - 1]是否是回文,那么我们注意到,其实i + 1 > j - 1。实际上i + 1 = (j - 1 + 1),但是这个情况其实也是回文。

所以我们要多初始化一位,让isP[i + 1][i] = 1 ,这是对长度为2的字串进行特殊的处理。

明白了这点。那么状态转移方程就很好写了:dp[i][j] = dp[i][j - 1] + dp[i + 1][j] - dp[i + 1][j - 1] + a[i] == a[j] && isP[i + 1][j - 1]。

#define N 5005
char a[N] ;
int dp[N][N] ;
int isP[N][N] ;
int main() {
scanf("%s",a + 1) ;
int n ;
cin >> n ;
int l = strlen(a + 1) ;
for (int i = 1 ; i <= l ; i ++ )dp[i][i] = 1 ,isP[i][i] = 1 , isP[i + 1][i] = 1 ;
for (int i = 2 ; i <= l ; i ++ ) {
for (int j = 1 ; j + i - 1 <= l ; j ++ ) {
int s = j ;
int e = j + i - 1 ;
isP[s][e] = isP[s + 1][e - 1] && a[s] == a[e] ;
dp[s][e] += dp[s + 1][e] + dp[s][e - 1] - dp[s + 1][e - 1] + isP[s][e];
}
}
while(n -- ) {
int aa , bb ;
RD(aa) ;
RD(bb) ;
OT(dp[aa][bb]) ;
puts("") ;
}
return 0 ;
}

HDU 4632 CF 245H 区间DP(回文)的更多相关文章

  1. HDU 4632 Palindrome subsequence(区间DP求回文子序列数)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4632 题目大意:给你若干个字符串,回答每个字符串有多少个回文子序列(可以不连续的子串).解题思路: 设 ...

  2. HDU 4632 Palindrome subsequence(区间dp,回文串,字符处理)

    题目 参考自博客:http://blog.csdn.net/u011498819/article/details/38356675 题意:查找这样的子回文字符串(未必连续,但是有从左向右的顺序)个数. ...

  3. HDU 4632 Palindrome subsequence (区间DP)

    题意 给定一个字符串,问有多少个回文子串(两个子串可以一样). 思路 注意到任意一个回文子序列收尾两个字符一定是相同的,于是可以区间dp,用dp[i][j]表示原字符串中[i,j]位置中出现的回文子序 ...

  4. CodeForces-245H:Queries for Number of Palindromes(3-14:区间DP||回文串)

    Times:5000ms: Memory limit:262144 kB 给定字符串S(|S|<=5000),下标由1开始.然后Q个问题(Q<=1e6),对于每个问题,给定L,R,回答区间 ...

  5. LightOJ - 1205:Palindromic Numbers (数位DP&回文串)

    A palindromic number or numeral palindrome is a 'symmetrical' number like 16461 that remains the sam ...

  6. dp回文

    .dp回文子串 通常在dp数组中存放的是 从i到j是否是回文子串 1.动态规划 2.中心扩展法 #include<iostream> #include<algorithm> # ...

  7. HDU 4745 Two Rabbits ★(最长回文子序列:区间DP)

    题意 在一个圆环串中找一个最长的子序列,并且这个子序列是轴对称的. 思路 从对称轴上一点出发,向两个方向运动可以正好满足题意,并且可以证明如果抽选择的子环不是对称的话,其一定不是最长的. 倍长原序列, ...

  8. hdu 4632区间dp 回文字串计数问题

    Palindrome subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65535 K (Java/ ...

  9. hdu 4745 Two Rabbits 区间DP

    http://acm.hdu.edu.cn/showproblem.php?pid=4745 题意: 有两只兔子Tom Jerry, 他们在一个用石头围城的环形的路上跳, Tom只能顺时针跳,Jerr ...

随机推荐

  1. javascript 基础学习整理

    1. javascript是动态语言,脚本语言,弱类型语言. 2. javascript代码在html文件中的位置安排,放在<body></body>内部与外部的区别.如何引用 ...

  2. 【转】爱普生打印机L358

    原文网址:http://www.chiphell.com/thread-838403-1-1.html 儿子幼儿园老是要打印作业,就决定用他的压岁钱买个打印机,主要以文件打印为主,兼顾照片.昨天网上一 ...

  3. 数据结构(线段树):SPOJ GSS3 - Can you answer these queries III

    GSS3 - Can you answer these queries III You are given a sequence A of N (N <= 50000) integers bet ...

  4. QTP关于AOM的Javascript启动方式

    序 QTP的AOM模型想必大家都很熟悉了,平时常用的就是通过VBS脚本的方式编写启动程序(也是我现在用的方法).其实,还有很多其他的方式,如Java,C#,JS,这些语言都是通过调用QTObjectM ...

  5. FusionCharts(v3.6.0)使用(1)

    前段时间做一个统计系统,需要画各种图表,于是找到了FusionCharts这个插件,功能甚是强大.在这个闲暇的春日午后,将这个插件的快速使用的方法写下来,方便懒得去官网看英文的朋友参考 安装 Fusi ...

  6. sublime text3安装SublimeREPL--解决不能运行input()的问题

    原文地址:http://blog.chinaunix.net/uid-12014716-id-4269991.html 一.安装包管理器(如果已经安装可以忽略) 1.简单的安装方法:使用Ctrl+`快 ...

  7. SRM 398(1-250pt)

    题意:有两个变量x和y,三种运算符+,*,-,组成等式"变量 运算符 变量 运算符 变量 运算符 变量",要求每个变量恰好出现两次,且等式的值为val的等式有多少个.注意不计算运算 ...

  8. 使用atomic一定是线程安全的吗

    这个问题很少遇到,但是答案当然不是.atomic在set方法里加了锁,防止了多线程一直去写这个property,造成难以预计的数值.但这也只是读写的锁定.跟线程安全其实还是差一些.看下面. @inte ...

  9. C#序列化和反序列化

    序列化和反序列化 序列化就是将一个对象的状态(各个属性量)保存起来,然后在适当的时候再获得. 序列化分为两大部分:序列化和反序列化.序列化是这个过程的第一部分,将数据分解成字节流,以便存储在文件中或在 ...

  10. Spring Boot 启动原理分析

    https://yq.aliyun.com/articles/6056 转 在spring boot里,很吸引人的一个特性是可以直接把应用打包成为一个jar/war,然后这个jar/war是可以直接启 ...