题意:求一个环的最长回文序列,是序列不是串

链接:点我

起点是可以任意的,

所以只要求出每个区间的最长回文序列之后取max(dp[1][i]+dp[i+1][n]),即可得最终答案

本来是想扩展两倍的,但是后来的最大不太好想

  1. 将 环倍增成链,求出窗口为n的最长子序列,但这不是最终的解,你可以试看看Sample 2,是只能得出4,因为它在选中的回文外面还可以选中一个当做起点来跳,所以外面得判断找出来的回文外面是否还有可以当起点的石头,即可以找窗口为(n- 1)的长度+1。所以解即找 窗口为n的长度或者 窗口为(n-1)的长度+1 的最大值。

  2. 不倍增,直接当成一个链求dp,然后把链切成两半,求出两边的回文长度,最大的和就是解。这里不用考虑起点问题,因为两边的回文中点都可以做起点。

Sample Input

  1. 1
  2. 1
  3. 4
  4. 1 1 2 1
  5. 6
  6. 2 1 1 2 1 3
  7. 0
    Sample Output
  1. 1
  2. 4
  3. 5
  4.  
  5. 2015-05-06 代码
  1. #include<cstdio>
  2. #include<iostream>
  3. #include<algorithm>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<queue>
  7. #include<map>
  8. using namespace std;
  9. #define MOD 1000000007
  10. const int INF=0x3f3f3f3f;
  11. const double eps=1e-;
  12. typedef long long ll;
  13. #define cl(a) memset(a,0,sizeof(a))
  14. #define ts printf("*****\n");
  15. const int MAXN=;
  16. int n,m,tt;
  17. int a[MAXN];
  18. int dp[MAXN][MAXN];
  19. int main()
  20. {
  21. int i,j,k;
  22. #ifndef ONLINE_JUDGE
  23. freopen("1.in","r",stdin);
  24. #endif
  25. while(scanf("%d",&n)!=EOF)
  26. {
  27. if(n==) break;
  28. cl(dp);
  29. for(i=;i<n;i++)
  30. {
  31. scanf("%d",&a[i]);
  32. dp[i][i]=;
  33. }
  34. for(int len=;len<n;len++)
  35. {
  36. for(i=;i+len<n;i++)
  37. {
  38. j=len+i;
  39. if(a[i]==a[j]) dp[i][j]=dp[i+][j-]+;
  40. else dp[i][j]=max(dp[i][j-],dp[i+][j]);
  41. }
  42. }
  43. int ans=;
  44. for(int i=;i<n;i++)
  45. ans=max(ans,dp[][i]+dp[i+][n-]);
  46. printf("%d\n",ans);
  47. }
  48. }

 

  1. #include<cstdio>
  2. #include<algorithm>
  3. #include<cstring>
  4. using namespace std;
  5. int dp[][];
  6. int a[];
  7. int n;
  8. int main()
  9. {
  10. while(scanf("%d",&n)&&n)
  11. {
  12. for(int i=;i<=n;i++)
  13. scanf("%d",&a[i]);
  14. memset(dp,,sizeof(dp));
  15. for(int i=;i<=n;i++)
  16. dp[i][i]=;
  17. for(int len=;len<n;len++) {
  18. for (int i=;i+len<=n;i++) {
  19. int j=i+len;
  20. if(a[i]==a[j])
  21. dp[i][j]=dp[i+][j-]+;
  22. else
  23. dp[i][j]=max(dp[i][j-],dp[i+][j]);
  24. }
  25. }
  26. int ans=;
  27. for(int i=;i<=n;i++)
  28. ans=max(ans,dp[][i]+dp[i+][n]);
  29. printf("%d\n",ans);
  30. }
  31. return ;
  32. }

hdu 4745 区间dp的更多相关文章

  1. hdu 4283 区间dp

    You Are the One Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  2. HDU 2829 区间DP & 前缀和优化 & 四边形不等式优化

    HDU 2829 区间DP & 前缀和优化 & 四边形不等式优化 n个节点n-1条线性边,炸掉M条边也就是分为m+1个区间 问你各个区间的总策略值最少的炸法 就题目本身而言,中规中矩的 ...

  3. HDU 4293---Groups(区间DP)

    题目链接 http://acm.split.hdu.edu.cn/showproblem.php?pid=4293 Problem Description After the regional con ...

  4. String painter HDU - 2476 -区间DP

    HDU - 2476 思路:分解问题,先考虑从一个空串染色成 B串的最小花费 ,区间DP可以解决这个问题 具体的就是,当 str [ l ] = = str [ r ]时 dp [ L ] [ R ] ...

  5. HDU 4632 区间DP 取模

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4632 注意到任意一个回文子序列收尾两个字符一定是相同的,于是可以区间dp,用dp[i][j]表示原字 ...

  6. 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) ...

  7. HDU 4570(区间dp)

    E - Multi-bit Trie Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u ...

  8. hdu 2476 区间dp

    题意: 给出两个串s1和s2,一次只能将一个区间刷一次,问最少几次能让s1=s2 例如zzzzzfzzzzz,长度为11,我们就将下标看做0~10 先将0~10刷一次,变成aaaaaaaaaaa 1~ ...

  9. hdu 4632(区间dp)

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

随机推荐

  1. Genymotion上不能安装APK软件的问题

    Genymotion模拟器不能安装APK的原因 官网给出的解释:Genymotion模拟器使用的是x86架构,在第三方市场上的应用有部分不采用x86这么一种架构,所以在编译的时候不通过,报“APP n ...

  2. Flask:初次使用Blueprints

    Windows 10家庭中文版,Python 3.6.4,Flask 1.0.2,Eclipse Oxygen.1a Release (4.7.1a),PyDev 6.3.2 本文为记录自己第一次使用 ...

  3. style一张图--openlayers

  4. 【前端vue开发】vue子调父 $emit (把子组件的数据传给父组件)

    ps:App.vue 父组件 Hello.vue 子组件 <!--App.vue :--> <template> <div id="app"> ...

  5. html5拖拽初窥

    说到拖动,大概有两种方式,一种是js实现,之前已经介绍过,今天来讲解另外一种方式,那就是使用html5实现拖动. css样式 .box { width: 200px; height: 200px; b ...

  6. 常见四大类型视频接线DP、HDMI、DVI、VGA的比较

    如今是新的“视”界,生活中总与各种屏幕打交道,难免会遇到选择视频接线的问题,要想搞清楚这点,我们只要通过了解现今常用的几种视频接线就会有个大致的认识.   281VGA.DVI.HDMI三种视频信号接 ...

  7. IntelliJ IDEA 去除IDE自动的参数名 提示功能

  8. Zookeeper原理架构与搭建

    一.Zookeeper到底是什么!? 学一个东西,不搞明白他是什么东西,哪还有心情学啊!! 首先,Zookeeper是Apache的一个java项目,属于Hadoop系统,扮演管理员的角色. 然后看到 ...

  9. NOIP2018初赛 解题报告(C++普及)

    第24届全国青少年信息学奥林匹克联赛初赛 普及组C++语言试题 竞赛时间:2018 年 10 月 13 日 14:30~16:30 选手注意: 1.试题纸共有 7 页,答题纸共有 2 页,满分 100 ...

  10. OS X 配置 Apache

    1.去掉javascript:void(0);Include /private/etc/apache2/extra/httpd-vhosts.con的注释,以启用虚拟主机: 2.在<Direct ...