hdu 2476 题解
题意
给出两个字符串 $ s1,s2 $,每次操作可以使一段连续的子串全变成一个字母,问最少多少次操作可以使 $ s1 $ 变为 $ s2 $.
例如 $ zzzzzfzzzzz $,长度为 $ 11 $ ,我们就将下标看做 $ 1~11 $
先将 $ 1-11 $ 刷一次,变成 $ aaaaaaaaaaa $
$ 2-10:abbbbbbbbba $
$ 2-8:abcccccccba $
$ 3-7:abcdddddcba $
$ 4-6:abcdeeedcab $
$ 5:abcdefedcab $
这样就 $ 6 $ 次,变成了 $ s2 $ 串了
第一眼看到这题,我就想到了这个
题意给出一个字符串,要求将一块空白木板刷成指定字符串,问最少操作次数(规则如上
我们可以定义 $ f[i][j] $ 表示从 $ i $ 刷到 $ j $ 的最少操作次数
转移方程
$ f[i][j]=f[i+1][j]+1 $
$ if(s1[i]==s1[k]) f[i][j]=min(f[i][j],f[i+1][j]+f[k+1][j]) $
$ i+1<=k>=j $
代码
#include<bits/stdc++.h>
using namespace std;
char str1[105];
int dp[105][105],ans[105];
int main(){
scanf("%s",str1+1);
int n=strlen(str1+1);
memset(dp,0,sizeof(dp));
for(int j=1;j<=n;++j){//枚举终点
for(int i=j;i;--i){//起点
dp[i][j]=dp[i+1][j]+1;//直接刷
for(int k=i+1;k<=j;++k){
if(str1[i]==str1[k]){//相同就枚举断点
dp[i][j]=min(dp[i][j],dp[i+1][k]+dp[k+1][j]);
}
}
}
}
printf("%d",dp[1][n]);
return 0;
}
仔细一想我们可以发现如果 $ s1,s2 $ 没有一个相同的字母那么不就是上面那题吗?
我们可以很容易发现,如果有相同字母那么就有可能缩小次数。
我们可以定义 $ f[i][j] $ 意义同上 $ ans[i] $ 表示到第 $ i $ 个字母所需要的最少次数
$ f $ 转移方程同上
$ if(str1[i]==str2[i]) \ ans[i]=ans[i-1] $ 字母相同直接转移
$ else \ ans[i]=min(ans[i],ans[j]+dp[j+1][i]) $ 字母不同考虑改变
$ 1<j<i $
代码
#include<bits/stdc++.h>
using namespace std;
char str1[105];
char str2[105];
int dp[105][105],ans[105];
int main(){
while(~scanf("%s %s",str1+1,str2+1)){
int n=strlen(str1+1);
memset(dp,0,sizeof(dp));
for(int j=1;j<=n;++j){
for(int i=j;i;--i){
dp[i][j]=dp[i+1][j]+1;
for(int k=i+1;k<=j;++k){
if(str2[i]==str2[k]){
dp[i][j]=min(dp[i][j],dp[i+1][k]+dp[k+1][j]);
}
}
}
}
for(int i=1;i<=n;++i) ans[i]=dp[1][i];
for(int i=1;i<=n;++i){
if(str1[i]==str2[i]) ans[i]=ans[i-1];
else{
for(int j=1;j<i;++j){
ans[i]=min(ans[i],ans[j]+dp[j+1][i]);
}
}
}
printf("%d\n",ans[n]);
}
return 0;
}
hdu 2476 题解的更多相关文章
- String painter HDU - 2476 -区间DP
HDU - 2476 思路:分解问题,先考虑从一个空串染色成 B串的最小花费 ,区间DP可以解决这个问题 具体的就是,当 str [ l ] = = str [ r ]时 dp [ L ] [ R ] ...
- String painter (hdu 2476 DP好题)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2476 题目大意: 给出两个等长的串S, T, 要将S变成T, 每次可以把S的连续的一段变成相同的字母 ...
- HDU 2476 String painter(区间DP+思维)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2476 题目大意:给你字符串A.B,每次操作可以将一段区间刷成任意字符,问最少需要几次操作可以使得字符串 ...
- HDU 2476 String painter (区间DP)
题意:给出两个串a和b,一次只能将一个区间刷一次,问最少几次能让a=b 思路:首先考虑最坏的情况,就是先将一个空白字符串刷成b需要的次数,直接区间DP[i][j]表示i到j的最小次数. 再考虑把a变成 ...
- HDU 2476 String painter(记忆化搜索, DP)
题目大意: 给你两个串,有一个操作! 操作时可以把某个区间(L,R) 之间的所有字符变成同一个字符.现在给你两个串A,B要求最少的步骤把A串变成B串. 题目分析: 区间DP, 假如我们直接想把A变成B ...
- HDU 2023题解分析
我想说这道题我还没弄明白我错哪了,交了20多遍一直都是Runtime Error,改了N次还是不对,后来搜了一下,说是数组开小了,又把数组开大,还不对,又改发现一个平均值求错,再改,还不对,洗洗睡吧. ...
- hdu 2476"String painter"(区间DP)
传送门 https://www.cnblogs.com/violet-acmer/p/9852294.html 题意: 给定字符串A,B,每次操作可以将字符串A中区间[ i , j ]的字符变为ch, ...
- HDU 2476 String painter(区间DP)
String painter Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- 2014年北京网络赛 Instrusive HDU 5040 题解 优先队列
网赛的时候看了这道题,发现就是平常的那种基础搜索题. 由于加了一个特殊条件:可以一次消耗3秒或原地停留1秒. 那就不能使用简单的队列了,需要使用优先队列才行. 题意 告诉一副地图:一个起点,一个终点, ...
随机推荐
- Mybatis异常-java.lang.IllegalArgumentException: invalid comparison:java.util.Date and java.lang.String
原因:在Mapper.xml中对非字符串类型的数据进行了是否为空判断,如date类型的数据Create_Date != '',decimal类型的数据price != ''都会报这个错误 只有字符串才 ...
- 第08组 Alpha冲刺(1/6)
队名:955 组长博客:https://www.cnblogs.com/cclong/p/11841141.html 作业博客:https://edu.cnblogs.com/campus/fzu/S ...
- Python之pygame学习绘制文字制作滚动文字
pygame绘制文字 ✕ 今天来学习绘制文本内容,毕竟游戏中还是需要文字对玩家提示一些有用的信息. 字体常用的不是很多,在pygame中大多用于提示文字,或者记录分数等事件. 字体绘制基本分为以下几个 ...
- 百度编辑器contentChange监听不到图片上传
将ueditor组件化到java项目中,当调用组件后,绑定函数,监听contentchange如下图: um.addListener("contentChange",functio ...
- Java ArrayList,LinkedList使用
1.ArrayList底层采用数组实现,当使用不带参数的构造方法生成ArrayList对象时,实际上回在底层生成一个长度为10的Object类型数组. 2.如果增加的元素个数超过10个,那么Array ...
- npm install 时 No matching version found for react-flow-design@1.1.14
执行 npm install时报错如下: 4017 silly pacote range manifest for react-highcharts@^16.0.2 fetched in 19ms40 ...
- GIS空间分析案例教程——带背景和周围要素的逐要素导出地理
GIS空间分析案例教程--带背景和周围要素的逐要素导出地理 商务合作,科技咨询,版权转让:向日葵,135-4855__4328,xiexiaokui#qq.com 目的:导出多边形要素类的每个要素 实 ...
- hyper-v启动虚拟机时提示“The application encountered an error while attempting to change the state of the machine ‘虚拟机名称'”如何处理?
1. 找出发生这一问题的事件代号 1.1 在开始菜单中搜索程序Event Viewer并点击进入 1.2 点击路径如下: “Applications and Services Logs > Mi ...
- Dart抽象类和多态
/* Dart中抽象类: Dart抽象类主要用于定义标准,子类可以继承抽象类,也可以实现抽象类接口. 1.抽象类通过abstract 关键字来定义 2.Dart中的抽象方法不能用abstract声明, ...
- 三、HTTP响应
HTTP消息是服务器和客户端之间交换数据的方式 有两种类型的消息: 请求--由客户端发送用来触发一个服务器上的动作 相应--来自服务器的应答 一.HTTP响应的构成 1.状态行 HTTP响应的起始行被 ...