UVA 11404 Palindromic Subsequence[DP LCS 打印]
UVA - 11404 |
题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串
不要求路径区间DP都可以做
然而要字典序最小
倒过来求LCS,转移同时维护f[i][j].s为当前状态字典序最小最优解
f[n][n].s的前半部分一定是回文串的前半部分(想想就行了)
当s的长度为奇时要多输出一个(因为这样长度+1,并且字典序保证最小(如axyzb bzyxa,就是axb|||不全是回文串的原因是后半部分的字典序回文串可能不是最小,多加的这一个是回文之间夹着的字典序最小的))
//
// main.cpp
// uva11404
//
// Created by Candy on 03/11/2016.
// Copyright © 2016 Candy. All rights reserved.
// #include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
const int N=1e3+;
char a[N],b[N];
int n;
//void dp(){
// n=strlen(a+1);
// ans=0;
// //for(int i=1;i<=n;i++) f[i][i]=1;
// for(int i=n;i>=1;i--){
// f[i][i]=1;
// for(int j=i+1;j<=n;j++){
// f[i][j]=max(f[i+1][j],f[i][j-1]);
// if(a[i]==a[j]) f[i][j]=max(f[i][j],f[i+1][j-1]+1);
// }
// }
//}
struct data{
int v;
string s;
data(){v=;s="";}
}f[N][N];
void dp(){
for(int i=;i<=n;i++) b[i]=a[n-i+]; for(int i=;i<=n;i++)
for(int j=;j<=n;j++){
if(a[i]==b[j]){
f[i][j].v=f[i-][j-].v+;
f[i][j].s=f[i-][j-].s+a[i];
}else{
if(f[i][j-].v>f[i-][j].v){
f[i][j].v=f[i][j-].v;
f[i][j].s=f[i][j-].s;
}else if(f[i-][j].v>f[i][j-].v){
f[i][j].v=f[i-][j].v;
f[i][j].s=f[i-][j].s;
}else{
f[i][j].v=f[i][j-].v;
f[i][j].s=min(f[i][j-].s,f[i-][j].s);
}
}
}
}
int main(int argc, const char * argv[]) {
while(scanf("%s",a+)!=EOF){
n=strlen(a+);
dp();
int len=f[n][n].v;
string s=f[n][n].s;
if(len&){
len/=;
for(int i=;i<len;i++) putchar(s[i]);
for(int i=len;i>=;i--) putchar(s[i]);//!
}else{
len/=;
for(int i=;i<len;i++) putchar(s[i]);
for(int i=len-;i>=;i--) putchar(s[i]);
}
putchar('\n');
} return ;
}
UVA 11404 Palindromic Subsequence[DP LCS 打印]的更多相关文章
- LPS UVA 11404 Palindromic Subsequence
题目传送门 题意:求LPS (Longest Palidromic Subsequence) 最长回文子序列.和回文串不同,子序列是可以不连续的. 分析:1. 推荐->还有一种写法是用了LCS的 ...
- UVA 11404 Palindromic Subsequence
Palindromic Subsequence Time Limit: 3000ms Memory Limit: 131072KB This problem will be judged on UVA ...
- UVa 11404 Palindromic Subsequence (LCS)
题意:给定一个字符串,问删除一些字符,使得它成为一个最长回访串,如果有多个,输出字典序最小的那个. 析: 我们可以把原字符串反转,然后求两个串的LCS,就得到最长回文串,不过要注意一些细节. 代码如下 ...
- UVA 531 - Compromise(dp + LCS打印路径)
Compromise In a few months the European Currency Union will become a reality. However, to join th ...
- UVA 10405 Longest Common Subsequence (dp + LCS)
Problem C: Longest Common Subsequence Sequence 1: Sequence 2: Given two sequences of characters, pri ...
- 【UVa】Palindromic Subsequence(dp+字典序)
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=465&page=s ...
- uva 111 - History Grading (dp, LCS)
题目链接 题意:给N,第二行是答案,n个数c1---cn, 代表第一个的顺序是c1,第二个数顺序是c2; 下面每一行是学生的答案,格式同上. 注意:这个给的顺序需要处理一下,不能直接用. 思路:LCS ...
- uva 11404 dp
UVA 11404 - Palindromic Subsequence 求给定字符串的最长回文子序列,长度一样的输出字典序最小的. 对于 [l, r] 区间的最长回文串.他可能是[l+1, r] 和[ ...
- UVA 11404 五 Palindromic Subsequence
Palindromic Subsequence Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu ...
随机推荐
- Asp.net 面向接口可扩展框架之应用程序上下文作用域组件
在团队中推广面向接口开发两年左右,成果总体来说我还是挺满意的,使用面向接口开发的模块使用Unity容器配置的功能非常稳定,便于共享迁移(另一个项目使用只需要复制配置和调用接口即可),如果再配合上DI那 ...
- 好股Android客户端开发
按比例排列 TextView 文字对齐 webview和js之间的交互 在WebView中如何让JS与Java安全地相互调用 Android Http请求方法汇总 ...
- yii的入口文件index.php中为什么会有这两句
yii的应用模板中,index.php中 前面会有这两句 <?php // comment out the following two lines when deployed to produc ...
- jqgrid学习笔记(转载)
jqgrid中文帮助文档网址:http://blog.mn886.net/jqGrid/ jqgrid:用来做什么? jqgrid是web端前台表格控件,用它可以轻松将数据格式化显示,前后台用过aja ...
- 转载:《TypeScript 中文入门教程》 4、类
版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 传统的JavaScript程序使用函数和基于原型的继承来创建可重用的组件,但这对 ...
- 高级Bash Scripting系列笔记--01之“什么情况不适用Bash Script”
1. 占用资源的任务,尤其那些影响速度的工作 比如排序,哈希,递归等等. 2. 大量使用数学运算 尤其是浮点运算,比如任意精度的计算或者复数计算等等,这类使用C++会好很多. 3. 跨平台的(适用 ...
- IT基础架构规划方案三(IT基础软件和系统规划)
IT基础软件和系统规划 操作系统选型规划方案 根据对某集团的实际调研,获取了企业业务应用系统的建设情况,随着企业信息化建设的推进,需要对各种信息化管理系统和应用系统的服务器选型进行选型规划,根据不同的 ...
- adb命令
一下是记录一些日常经常用的adb command, adb root: adb shell -> su -> return -> adb root(首先让安卓设备获得root权限,然 ...
- JS时间戳格式化日期时间
由于mysql数据库里面存储时间存的是时间戳,取出来之后,JS要格式化一下显示.(李昌辉) 用的次数比较多,所以写了一个简单方法来转换: //时间戳转时间 function RiQi(sj) { va ...
- 操作数数据类型 ntext 对于 max 运算符无效
SoStyle.chi_description AS chi_description, SoStyle.description AS eng_description, SoStyle.chi_qual ...