HDU 1513 Palindrome:LCS(最长公共子序列)or 记忆化搜索
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1513
题意:
给你一个字符串s,你可以在s中的任意位置添加任意字符,问你将s变成一个回文串最少需要添加字符的个数。
题解1(LCS):
很神奇的做法。
先求s和s的反串的LCS,也就是原串中已经满足回文性质的字符个数。
然后要变成回文串的话,只需要为剩下的每个落单的字符,相应地插入一个和它相同的字符即可。
所以答案是:s.size()-LCS(s,rev(s))
另外,求LCS时只会用到lcs[i-1][j-1],lcs[i-1][j],lcs[i][j-1],因为空间不够,改为滚动数组,将第一维[MAX_N]变为[2]。
题解2(记忆化搜索):
做法是对的,但是空间占用太大,会MLE。
dfs(x,y)表示让s串中[x,y]这个区间变为回文串的花费。
两种情况:
(1)s[x]==s[y]:
s[x]和s[y]已经配对,所以return dfs(x+1,y-1);
(2)s[x]!=s[y]:
有两种解决办法:
1.让[x+1,y]变为回文串,然后在y的右边添加一个字符等于s[x]。
2.让[x,y-1]变为回文串,然后在x的左边添加一个字符等于s[y]。
所以return min(dfs(x+1,y),dfs(x,y-1))+1;
判断dfs结束边界:
(1)dp[x][y]!=-1:之前已经算过了,那就不用再算一遍了,return dp[x][y]。
(2)x==y: return 0;
(3)x+1==y: 如果s[x]==s[y],return 0;如果s[x]!=s[y],return 1;
另外,每次dfs算出新的dp时,及时保存到dp数组中。
AC Code:
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#define MAX_N 5005 using namespace std; int n;
int dp[][MAX_N];
string s; int lcs(string a,string b)
{
memset(dp,,sizeof(dp));
for(int i=;i<=a.size();i++)
{
for(int j=;j<=b.size();j++)
{
if(a[i-]==b[j-]) dp[i&][j]=dp[(i-)&][j-]+;
else dp[i&][j]=max(dp[(i-)&][j],dp[i&][j-]);
}
}
return dp[a.size()&][b.size()];
} int palindrome(string s)
{
string rev=s;
reverse(rev.begin(),rev.end());
return s.size()-lcs(s,rev);
} int main()
{
while(cin>>n>>s)
{
cout<<palindrome(s)<<endl;
}
}
没AC Code:
// dp[x][y] = min num of chars appended to s
// dp[x][x] = 0
//
// 1) s[i] != s[j]:
// dp[x][x+1] = 1
// dp[x][y] = min(dp[x+1][y], dp[x][y-1]) + 1
//
// 2) s[i] == s[j]
// dp[x][y] = dp[x+1][y-1] #include <iostream>
#include <stdio.h>
#include <string.h>
#define MAX_N 5005 using namespace std; int n;
int dp[MAX_N][MAX_N];
string s; int dfs(int x,int y)
{
if(dp[x][y]!=-) return dp[x][y];
if(x==y) return dp[x][y]=;
if(x+==y) return dp[x][y]=(s[x]==s[y]?:);
if(s[x]==s[y]) return dp[x][y]=dfs(x+,y-);
return dp[x][y]=min(dfs(x+,y),dfs(x,y-))+;
} int main()
{
while(cin>>n>>s)
{
memset(dp,-,sizeof(dp));
cout<<dfs(,s.size()-)<<endl;
}
}
HDU 1513 Palindrome:LCS(最长公共子序列)or 记忆化搜索的更多相关文章
- HDU 1513 Palindrome(最长公共子序列)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1513 解题报告:给定一个长度为n的字符串,在这个字符串中插入最少的字符使得这个字符串成为回文串,求这个 ...
- 算法设计 - LCS 最长公共子序列&&最长公共子串 &&LIS 最长递增子序列
出处 http://segmentfault.com/blog/exploring/ 本章讲解:1. LCS(最长公共子序列)O(n^2)的时间复杂度,O(n^2)的空间复杂度:2. 与之类似但不同的 ...
- POJ 1458 Common Subsequence(LCS最长公共子序列)
POJ 1458 Common Subsequence(LCS最长公共子序列)解题报告 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?c ...
- 动态规划模板2|LCS最长公共子序列
LCS最长公共子序列 模板代码: #include <iostream> #include <string.h> #include <string> using n ...
- LCS 最长公共子序列
区别最长公共子串(连续) ''' LCS 最长公共子序列 ''' def LCS_len(x, y): m = len(x) n = len(y) dp = [[0] * (n + 1) for i ...
- HDU 1159 Common Subsequence 最长公共子序列
HDU 1159 Common Subsequence 最长公共子序列 题意 给你两个字符串,求出这两个字符串的最长公共子序列,这里的子序列不一定是连续的,只要满足前后关系就可以. 解题思路 这个当然 ...
- hdu 1159 Common Subsequence(LCS最长公共子序列)
Common Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- LCS最长公共子序列~dp学习~4
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1513 Palindrome Time Limit: 4000/2000 MS (Java/Others ...
- LCS最长公共子序列(最优线性时间O(n))
这篇日志主要为了记录这几天的学习成果. 最长公共子序列根据要不要求子序列连续分两种情况. 只考虑两个串的情况,假设两个串长度均为n. 一,子序列不要求连续. (1)动态规划(O(n*n)) (转自:h ...
- LCS最长公共子序列
问题:最长公共子序列不要求所求得的字符串在所给字符串中是连续的,如输入两个字符串ABCBDAB和BDCABA,字符串BCBA和BDAB都是他们的公共最长子序列 该问题属于动态规划问题 解答:设序列X= ...
随机推荐
- js字符串转换为数字 总结
a. 将一个字符串转换为数字的一种缺少些技巧但是很清楚明白的方法就是:把Number()构造函数作为一个函数来调用: var number = Number(string_value); b. pa ...
- Linux系统介绍
类似Windows, Linux也是一个操作系统,Linux是一套开放源代码程序,并可以自由传播的类Unix操作系统软件,多用户,多任务并且支持多线程和多CPU的操作系统. Linux系统主要被应用于 ...
- Spring MVC 项目搭建 -2- 添加service ,dao,junit
Spring MVC 项目搭建 -2- 添加service ,dao,junit 1.dao public class Hero { private String name; public Strin ...
- URLConnection调用接口
写在前面: 项目是java web,jdk1.4,weblogic 7;对方.net系统,用wcf开发的接口.对方提供接口url地址,以及说明用post方式去调用,无需传递参数,直接返回json ar ...
- 详解react/redux的服务端渲染:页面性能与SEO
亟待解决的疑问 为什么服务端渲染首屏渲染快?(对比客户端首屏渲染) react客户端渲染的一大痛点就是首屏渲染速度慢问题,因为react是一个单页面应用,大多数的资源需要在首次渲染前就加载 ...
- Egret的项目结构
这是我新建的一个Egret EUI项目 .wing文件夹是项目的配置文件 bin-debug 文件夹,项目编译和运行的debug目录 libs 文件夹,存放库文件,包括 Egret 核心库,其他扩展库 ...
- 设计模式 - 观察者模式(JDK)
定义:观察者模式定义了对象之间的一对多依赖,这样一来,当一个对象改变状态时,它的所有依赖者都会收到通知并自动更新. 对象: 抽象主题角色:每个抽象主题角色都可以有任意数量的观察者.抽象主题提供可 ...
- 由max_allowed_packet引发的mysql攻防大战
1.原因 程序的sql语句比较长.max_allowed_packet默认是1024.于是就报错了.一开始手动改 global max_allowed_packet ,改完后.莫名奇妙被还原.后来改配 ...
- HTML中使用JavaScript的三种方式及优缺点
1.内部js: 在直接在页面的<script></script>标签内写js代码 优点:相对于使用行内js,内部js代码较为集中,与页面结构的实现代码耦合度较低,比较便于维 ...
- 关于springmvc配置validator的注意事项
<mvc:annotation-driven validator="validator" /> 在使用springmvc整合hibernate-validator做表单 ...