uva1625
思路:每次选择颜色面临有两个选择: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的更多相关文章
- [UVA1625]Color Length
题面在这里 description 输入两个长度分别为\(n\)和\(m\)的颜色序列,要求按顺序合并成同一个序列,即每次可以把一个序列开头的颜色放到新序列的尾部. 对于每个颜色\(c\)来说,其跨度 ...
- [水题日常]UVA1625 Color Length
来整理一下思路- 一句话题意:给两个大写字母的序列,每次取出其中一个数列的第一个元素放到新序列里面,对每个字母\(c\)记它的跨度\(L(c)\)为这个字母最后出现的位置-第一次出现的位置,求新序列所 ...
- UVA - 1625 Color Length[序列DP 代价计算技巧]
UVA - 1625 Color Length 白书 很明显f[i][j]表示第一个取到i第二个取到j的代价 问题在于代价的计算,并不知道每种颜色的开始和结束 和模拟赛那道环形DP很想,计算这 ...
- UVA - 1625 Color Length[序列DP 提前计算代价]
UVA - 1625 Color Length 白书 很明显f[i][j]表示第一个取到i第二个取到j的代价 问题在于代价的计算,并不知道每种颜色的开始和结束 和模拟赛那道环形DP很想,计算这 ...
- UVa 1625 颜色的长度
https://vjudge.net/problem/UVA-1625 题意: 输入两个长度分别为n和m的颜色序列,要求按顺序合并成同一个序列,即每次可以把一个序列开头的颜色放到新序列的尾部.对于每个 ...
- DP小合集
1.Uva1625颜色的长度 dp[i][j]表示前一个串选到第i个 后一个串选到第j个 的最小价值 记一下还有多少个没有结束即dp2 记一下每个数开始和结束的位置 #include<cstdi ...
- UVA-1625-Color Length(DP LCS变形)
Color Length(UVA-1625)(DP LCS变形) 题目大意 输入两个长度分别为n,m(<5000)的颜色序列.要求按顺序合成同一个序列,即每次可以把一个序列开头的颜色放到新序列的 ...
随机推荐
- Linux下安装mysql(yum和源码编译两种方式)
这里介绍Linux下两种安装mysql的方式:yum安装和源码编译安装. 1. yum安装 (1)首先查看centos自带的mysql是否被安装: # yum list installed |grep ...
- 深入理解Java虚拟机读书笔记(一)- java内存区域和垃圾收集
jvm内存模型如下图 垃圾回收: 方法区: 这部分的垃圾回收性价比低,一般不要求回收,暂认为是永久代 heap:新生代和永久代之分.永久代主要回收废弃常量和无用的类. 垃圾回收算法: 1. 标记-清除 ...
- Java 生产者消费者模式详细分析
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
- PHP date函数详解
在页面的最前页加上date_default_timezone_set(PRC); /*把时间调到北京时间,php5默认为格林威治标准时间*/date ()a: "am"或是 ...
- Eclipse运行Java简单实例
运行eclipse前首先配置好JDK环境变量等 双击这句话可跳转配置环境变量详细步骤 运行eclipse软件 1.File菜单-New - project 2.Java Project - Next ...
- R语言-探索多个变量
目的: 通过探索文件pseudo_facebook.tsv数据来学会多个变量的分析流程 通过探索diamonds数据集来探索多个变量 通过酸奶数据集探索多变量数据 知识点: 散点图 dplyr汇总数据 ...
- 学习dos命令行总结
dir:列出当前目录下的所有文件及文件夹. md 文件夹:创建文件夹 rd 文件夹:删除文件夹 echo 文件内容>文件名(扩展名):创建带文件内容的新文件 echo 文件内容>>文 ...
- c# 颜色RGB到HSB互相转换
/// <summary> /// 色相,饱和度,亮度转换成rgb值 /// </summary> /// <returns></returns> pu ...
- wpf timePicker 时间选择控件
wpf里有日期选择控件,但没有时间选择控件.其他地方也有类似的,但效果并不太好,而且复杂.所以就自己写了个.参考codeproject上的. 分两部分. 第一部分是.cs文件.也就是control控件 ...
- fiddler2请求参数乱码
win7 1.windows按钮+R 2.输入regedit +回车+是 3.HKEY_CURRENT_USER\Software\Microsoft\Fiddler2 4.右键新建,选字符串值 加上 ...