回文字符串

时间限制:3000 ms  |  内存限制:65535 KB
难度:4
描写叙述
所谓回文字符串,就是一个字符串。从左到右读和从右到左读是全然一样的。比方"aba"。当然,我们给你的问题不会再简单到推断一个字符串是不是回文字符串。如今要求你,给你一个字符串,可在任何位置加入字符。最少再加入几个字符,能够使这个字符串成为回文字符串。

输入
第一行给出整数N(0<N<100)

接下来的N行。每行一个字符串,每一个字符串长度不超过1000.
输出
每行输出所需加入的最少字符数
例子输入
1
Ab3bd
例子输出
2
来源

IOI 2000

開始看到这道题的时候,一时想不出用什么非常好的方法来做。看到分类是在动态规划,也大致往这方面想。看了别人的思路。顿时茅塞顿开啊,直接把给定的字符串倒转,然后再和原字符串一起,求他们的最长公共序列,然后再拿字符串的长度减去他们的最长公共序列的长度,得到的就是要加入的最小的字符数。想到了这个地方,这个题目就非常好解啦;直接用LIC水过,状态方程式也和前面做过的题一样;

#include <cstdio>
#include <cstring>
#define max(a,b) a>b?a:b
const int maxn=1001;
char a[maxn],b[maxn];
int dp[maxn][maxn];//昨天晚上把DP的类型设置成了char型,然后提交一直wa,刷屏了。。 。不应该啊!。
int main()
{
int n,i,j,len;
scanf("%d",&n);
while(n--)
{
memset(a,0,sizeof(a));
memset(dp,0,sizeof(dp));
scanf("%s",a);
len=strlen(a);
for(i=len-1,j=0;i>=0;i--)
b[j++]=a[i];
for(i=1;i<=len;i++)
{
for(j=1;j<=len;j++)
{
if(a[i-1]==b[j-1]) dp[i][j]=dp[i-1][j-1]+1;//递推关系
else
dp[i][j]=max(dp[i-1][j],dp[i][j-1]);
}
}
printf("%d\n",len-dp[len][len]);
}
}

看到别人的写的,用了还有一种思路,也是动态规划。可是递推关系有一点不同;有点没看懂;

省去了倒转的环节;

#include<stdio.h>
#include<string.h> int f[1005][1005]; int main()
{
int n;
scanf("%d",&n);
while (n--)
{
char s[1005];
scanf("%s",s);
int k,i,j,l=strlen(s); for (i=0;i<l;++i) f[i][i]=0; for (k=2;k<=l;++k)
{
for (i=0;i<=l-k;++i)
{
int p=i+k-1;
if (s[i]==s[p])
{
f[i][p]=f[i+1][p-1];
}
else
{
f[i][p]=1+(f[i][p-1]<f[i+1][p]? f[i][p-1]:f[i+1][p]);
}
}
} printf("%d\n",f[0][l-1]);
memset(f,0,sizeof(f));
} return 0;
}

看到别人的最优代码,内存占用的非常小。值得学习,另一种滚动数组。好像能够节约内存。还没有接触过;


#include<stdio.h>
#include<string.h>
using namespace std;
int m[1000],i,j,t1,t2,len;
char s[1001];
int main() {
int N;
scanf("%d",&N);
while(N--){
scanf("%s",s);
len=strlen(s);
for(i=len-1;i>=0;i--){
m[i]=0;
t1=m[i];
for(j=i+1;j<len;j++){
t2=m[j];
if(s[i]==s[j])
m[j]=t1;
else
m[j]=m[j-1]<m[j]?m[j-1]+1:m[j]+1;
t1=t2;
}
}
printf("%d\n",m[len-1]);
}
}

nyist oj 37 回文字符串 (动态规划经典)的更多相关文章

  1. nyoj 题目37 回文字符串

    回文字符串 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的,比如"aba".当 ...

  2. [NYOJ 37] 回文字符串

    回文字符串 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的,比如"aba".当 ...

  3. nyoj 37 回文字符串 【DP】

    先反向复制一个新的字符串,然后再找出最长公共子串,在用长度n减去就可以 回文字符串 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描写叙述 所谓回文字符串,就是一个字符串,从 ...

  4. leetcode5 最长回文字符串 动态规划 Manacher法

    dp 注意没有声明S不空,处理一下 o(n^2) class Solution { public: string longestPalindrome(string s) { if (s.empty() ...

  5. nyist oj 311 全然背包 (动态规划经典题)

    全然背包 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描写叙述 直接说题意,全然背包定义有N种物品和一个容量为V的背包.每种物品都有无限件可用.第i种物品的体积是c,价值是 ...

  6. NYOJ -37回文字符串

    这道题看了好大会没有思路,上网一搜发现这么简单,但是我为什么就想不到呢,??就是求和它的逆序之后的字符串最长公共子序列,然后用总的长度减去它就行了.原因是是因为只要是在公共子序列里面,那么他就是对称的 ...

  7. 【九度OJ】题目1192:回文字符串 解题报告

    [九度OJ]题目1192:回文字符串 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1192 题目描述: 给出一个长度不超过1000的 ...

  8. 九度OJ 1192:回文字符串 (基础题)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3807 解决:1778 题目描述: 给出一个长度不超过1000的字符串,判断它是不是回文(顺读,逆读均相同)的. 输入: 输入包括一行字符串 ...

  9. 九度oj 题目1192:回文字符串

    题目1192:回文字符串 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4391 解决:2082 题目描述: 给出一个长度不超过1000的字符串,判断它是不是回文(顺读,逆读均相同)的. ...

随机推荐

  1. linux之awk手册

    awk 手册   原文 Table of Contents 1. awk简介 2. awk命令格式和选项 2.1. awk的语法有两种形式 2.2. 命令选项 3. 模式和操作 3.1. 模式 3.2 ...

  2. COGS【831】最短网络

    831. [USACO 3.1] 最短网络 ★   输入文件:agrinet.in   输出文件:agrinet.out   简单对比 时间限制:1 s   内存限制:128 MB usaco/agr ...

  3. SQL查询重复记录方法大全 转

    原文发布时间为:2010-08-09 -- 来源于本人的百度文章 [由搬家工具导入] 查找所有重复标题的记录: SELECT *FROM t_info aWHERE ((SELECT COUNT(*) ...

  4. hdu 2104(判断互素)

    hide handkerchief Time Limit: 10000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  5. Oracle 索引(转)

    一.索引介绍 1.1 索引的创建语法: CREATE UNIUQE | BITMAP INDEX <schema>.<index_name> ON <schema> ...

  6. webpack学习(一)安装和命令行、一次js/css的打包体验及不同版本错误

    一.前言 找了一个视频教程开始学习webpack,跟着视频学习,在自己的实际操作中发现,出现了很多问题.基本上都是因为版本的原因而导致,自己看的视频是基于webpack 1.x版,而自己现在早已是we ...

  7. Machine Learning Done Wrong【转】

    1. Take default loss function for granted Many practitioners train and pick the best model using the ...

  8. Django性能调优

    1.针对数据库的调优 程序对数据库的多次访问,会影响速度. 一般的流程是建立连接,获取或者修改数据,关闭连接.如果多次请求,导致多次建立连接会影响到速度. 解决办法有:1.延长连接时间并执行多次操作 ...

  9. php 开发 错误汇总

    [问题]nginx thinkphp中 除首页外全显示404 Not Found,非rewrite问题,Linux+nginx环境 [解决方案]: 1.在nginx下重新支持pathinfo模式 2. ...

  10. 基于WPF系统框架设计(9)-多值绑定之IMultiValueConverter

    应用场景 我想把View层的一个布局控件和功能按钮传到ViewModel层,达到动态变更布局,同时灵活获取功能按钮的属性,让View和ViewModel完全分离,而不受View层影响. 最后我想到使用 ...