思路:每次选择颜色面临有两个选择: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. Can’t open /dev/* exclusively. Mounted filesystem?解决

    1 错误提示:Can’t open /dev/* exclusively. Mounted filesystem? 做完软件RAID之后,根据鸟哥书上的操作,其实没有真正删除软件RAID,导致出现如下 ...

  2. Ubuntu 安装 Nginx 实现反向代理

    安装Nginx依赖库(ubuntu平台) 最近域名通过了备案, 想着应用总不能带着端口号访问吧, 于是在网上踩了很多坑, 终于找到了一步直达的方法,起码这一次很顺利的实现了 安装gcc g++的依赖库 ...

  3. JSP -java service pages

    jsp的运行机制: 1客户端(请求jsp页面)------->JSP页面(转换为java源文件)------->Selvet文件(.java) (编译成相应的字节码文件也就是后缀名是.cl ...

  4. 【转】Linux 服务器安全配置

    第一部分:RedHat Linux篇1.概述 Linux服务器版本:RedHat Linux AS 2.1 对于开放式的操作系统---Linux,系统的安全设定包括系统服务最小化.限制远程存取.隐藏重 ...

  5. java 数组与集合(list)相互转化

    上代码 package com.core.array2collection; import java.util.ArrayList; import java.util.Arrays; import j ...

  6. 数据库MySQL的基本操作

    1.MySQL数据库的安装: CentOS6上mysql服务端和客户端的安装和启动: #使用yum安装mysql数据库的服务端和客户端 yum install -y mysql mysql-serve ...

  7. pandas教程

    对pandas做最简单的介绍,针对初学者. 一.引入相关模块模块 import numpy as np import pandas as pd import matplotlib.pyplot as ...

  8. require和require_once的区别

    require 的使用方法如 require("./inc.php"); .通常放在 PHP 程式的最前面,PHP 程式在执行前,就会先读入 require 所指定引入的档案,使它 ...

  9. 用fiddler2调试localhost

    1.用 http://localhost. (locahost紧跟一个点号): 2.用 http://127.0.0.1. (127.0.0.1紧跟一个点号): 3.用 http://machinen ...

  10. BZOJ 1116: [POI2008]CLO [连通分量]

    Byteotia城市有n个 towns m条双向roads. 每条 road 连接 两个不同的 towns ,没有重复的road. 你要把其中一些road变成单向边使得:每个town都有且只有一个入度 ...