思路:每次选择颜色面临有两个选择:1、序列A的首部颜色 2、序列B的首部元素,定义状态d[i][j]表示A序列已经选取了前i个颜色,B序列已经选取了前j个颜色的情况下最小的L(c)总和。 状态转移:cnt1表示在状态d[i-1][j]将第i个颜色放入时"已经出现但尚未结束的颜色种数",同理,cnt2表示在状态d[i][j-1]将第j个颜色放入时"已经出现但尚未结束的颜色种数",得到dp[i][j]=min(dp[i-1][j]+cnt1,dp[i][j-1]+cnt2);

AC代码:

#include<cstdio>
#include<cstring>
#include<set>
#include<algorithm>
using namespace std;
const int maxn=5001;
char a[maxn],b[maxn];
int d[30][2][2],dp[maxn][maxn];
void solve(){
	set<char>ss;
	int n=strlen(a),m=strlen(b);
	for(int i=0;i<n;++i) ss.insert(a[i]);
	for(int i=0;i<m;++i) ss.insert(b[i]);
	memset(d,-1,sizeof(d));
	for(int i=0;i<26;++i){
		char c='A'+i;
		if(!ss.count(c)) continue;
		for(int j=0;j<n;++j){
			if(a[j]==c) {
				d[i][0][0]=j;
				break;
			}
		}
		for(int j=n-1;j>=0;--j){
			if(a[j]==c) {
				d[i][0][1]=j;
				break;
			}
		}
		for(int j=0;j<m;++j){
			if(b[j]==c) {
				d[i][1][0]=j;
				break;
			}
		}
		for(int j=m-1;j>=0;--j){
			if(b[j]==c) {
				d[i][1][1]=j;
				break;
			}
		}
	}
	for(int i=0;i<=n;++i)
	for(int j=0;j<=m;++j){
		if(i==0&&j==0) {
			dp[i][j]=0;
			continue;
		}
		int f1=1,f2=1;
		if(i-1<0) f1=0;
		if(j-1<0) f2=0;
		//可选a[i] or b[j]
		int cnt1=0,cnt2=0;
		for(int k=0;k<26;++k){
			if(((d[k][0][0]+1<i&&d[k][0][0]!=-1)||(d[k][1][0]+1<=j&&d[k][1][0]!=-1))&&(d[k][0][1]+1>=i||d[k][1][1]+1>j))
				cnt1++;
			if(((d[k][0][0]+1<=i&&d[k][0][0]!=-1)||(d[k][1][0]+1<j&&d[k][1][0]!=-1))&&(d[k][0][1]+1>i||d[k][1][1]+1>=j))
				cnt2++;
		}
		if(f1&&f2) dp[i][j]=min(dp[i-1][j]+cnt1,dp[i][j-1]+cnt2);
		else if(f1) dp[i][j]=dp[i-1][j]+cnt1;
		else dp[i][j]=dp[i][j-1]+cnt2;
	}
	printf("%d\n",dp[n][m]);
}
int main(){
	int T;
	scanf("%d",&T);
	while(T--){
		scanf("%s%s",a,b);
		solve();
	}
	return 0;
}

如有不当之处欢迎指出!

uva1625的更多相关文章

  1. [UVA1625]Color Length

    题面在这里 description 输入两个长度分别为\(n\)和\(m\)的颜色序列,要求按顺序合并成同一个序列,即每次可以把一个序列开头的颜色放到新序列的尾部. 对于每个颜色\(c\)来说,其跨度 ...

  2. [水题日常]UVA1625 Color Length

    来整理一下思路- 一句话题意:给两个大写字母的序列,每次取出其中一个数列的第一个元素放到新序列里面,对每个字母\(c\)记它的跨度\(L(c)\)为这个字母最后出现的位置-第一次出现的位置,求新序列所 ...

  3. UVA - 1625 Color Length[序列DP 代价计算技巧]

    UVA - 1625 Color Length   白书 很明显f[i][j]表示第一个取到i第二个取到j的代价 问题在于代价的计算,并不知道每种颜色的开始和结束   和模拟赛那道环形DP很想,计算这 ...

  4. UVA - 1625 Color Length[序列DP 提前计算代价]

    UVA - 1625 Color Length   白书 很明显f[i][j]表示第一个取到i第二个取到j的代价 问题在于代价的计算,并不知道每种颜色的开始和结束   和模拟赛那道环形DP很想,计算这 ...

  5. UVa 1625 颜色的长度

    https://vjudge.net/problem/UVA-1625 题意: 输入两个长度分别为n和m的颜色序列,要求按顺序合并成同一个序列,即每次可以把一个序列开头的颜色放到新序列的尾部.对于每个 ...

  6. DP小合集

    1.Uva1625颜色的长度 dp[i][j]表示前一个串选到第i个 后一个串选到第j个 的最小价值 记一下还有多少个没有结束即dp2 记一下每个数开始和结束的位置 #include<cstdi ...

  7. UVA-1625-Color Length(DP LCS变形)

    Color Length(UVA-1625)(DP LCS变形) 题目大意 输入两个长度分别为n,m(<5000)的颜色序列.要求按顺序合成同一个序列,即每次可以把一个序列开头的颜色放到新序列的 ...

随机推荐

  1. python_如何为创建大量实例节省内存?

    案例: 某网络游戏中,定义了玩家类Player(id, name, status,....),每有一个在线玩家,在服务器程序内有一个Player的实例,当在线人数很多时,将产生大量实例(百万级别) 需 ...

  2. vi使用手册

    VI是unix上最常用的文本编辑工具,我自己电脑上面也装了VIM编辑器,这个据称是程序员码字神器我实在没觉得那里舒服了,所以又用回了自己的Sublime.这里整理下vi常用操作,如果以后直接在Linu ...

  3. MySQL中时间函数NOW()和SYSDATE()的区别

    mysql中日期函数还是比较常用的.主要有NOW()和SYSDATE()两种,虽然都表示当前时间,但使用上有一点点区别. NOW()取的是语句开始执行的时间,SYSDATE()取的是动态的实时时间. ...

  4. springMVC注解方式+easyUI+MYSQL配置实例

    刚接触springMVC,使用的注解方式,也在学习阶段,所以把自己学习到的记下来.本文利用springMVC从数据库读取用户信息为例,分享一下. 1.准备相关架包及资源.因为使用springMVC+e ...

  5. MOOC网视频下载并视频倍速播放,超简单哒,亲测可用,( •̀ ω •́ )y

    由于视频在线播放太卡,想着下载看吧~~可是这个坑爹的网站没有下载按钮,难道就不可以下载视频了吗? 小白不甘心~ 于是动手查了一下,实验很成功,估计如果会爬虫的都不用像我一样一个一个自己去下了,奈何我知 ...

  6. R 调用 python

    上一篇说了python使用 rpy2 调用 R,这里介绍R如何调用python.R的强项在于统计方面,尤其是专业的统计分析,统计检验以及作图功能十分强大,但是在通用性方面,就远不如Python了,比如 ...

  7. oracle case when及decode的用法

    case ... when 语句 1) CASE column_name WHEN value1 THEN resutl1,... [ ELSE result ] END select name , ...

  8. python os模块实用函数

    os.sep可以取代操作系统特定的路径分隔符.windows下为 “\\” os.name字符串指示你正在使用的平台.比如对于Windows,它是'nt',而对于Linux/Unix用户,它是'pos ...

  9. Java8之Lambda表达式基础

    Java 8中,将会提供对lambda的支持,函数式编程FP(Functional Programming)将会得到很好地支持,而函数式编程的一个重要特点就是适合并行运算. λ:希腊字母表中排序第十一 ...

  10. BZOJ 2754: [SCOI2012]喵星球上的点名 [后缀数组+暴力]

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1906  Solved: 839[Submit][St ...