传送门

我们先考虑从一个空白串变成\(B\),这样的话用区间dp,区间dp,设\(f[l][r]\)表示区间\((l,r)\)的最小次数,当\(l==r\)时为\(1\),当\(s[l]==s[r]\)时为\(min(f[l][r-1],f[l+1][r])\),否则枚举断点\(k\),为\(min(f[l][k]+f[k+1][r])\)
然后考虑从\(A\)变成\(B\),设\(dp[i]\)表示\(A\)的前\(i\)个字母变成\(B\)的最小次数,一开始先设成\(f[1][i]\),如果\(A[i]==B[i]\)那么设为\(dp[i-1]\),然后枚举断点\(k\),则\(dp[i]=min\{dp[k]+f[k+1][i]\}\)

//minamoto
#include<bits/stdc++.h>
#define R register
#define inf 0x3f3f3f3f
#define min(x,y) ((x)<(y)?(x):(y))
#define fp(i,a,b) for(R int i=a,I=b+1;i<I;++i)
#define fd(i,a,b) for(R int i=a,I=b-1;i>I;--i)
#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
using namespace std;
const int N=105;
int f[N][N],dp[N],n;char A[N],B[N];
void solve(){n=strlen(A+1),memset(f,0x3f,sizeof(f)),memset(dp,0x3f,sizeof(dp));fp(i,0,n)f[i][i]=1;fp(l,1,n-1)fp(i,1,n-l){if(B[i]==B[i+l])f[i][i+l]=min(f[i+1][i+l],f[i][i+l-1]);else fp(k,i,i+l-1)f[i][i+l]=min(f[i][i+l],f[i][k]+f[k+1][i+l]);}dp[1]=A[1]==B[1]?0:1;fp(i,2,n){dp[i]=f[1][i];if(A[i]==B[i])dp[i]=min(dp[i],dp[i-1]);else fp(j,1,i-1)dp[i]=min(dp[i],dp[j]+f[j+1][i]);}printf("%d\n",dp[n]);
}
int main(){
//  freopen("testdata.in","r",stdin);while(~scanf("%s%s",A+1,B+1))solve();return 0;
}

转载于:https://www.cnblogs.com/bztMinamoto/p/10082226.html

UVA1437 String painter相关推荐

  1. uva live 4394 String painter 间隔dp

    // uva live 4394 String painter // // 问题是,在培训指导dp运动主题,乍一看,我以为只是一点点复杂 // A A磕磕磕,两个半小时后,.发现超过例子.然而,鉴于他 ...

  2. 动态规划训练11 [String painter HDU - 2476]

    String painter HDU - 2476 题意: 我认为这是一道比较难的问题,自己想了很久,没有想出来怎么做,可能是因为思维僵化吧,一直在想怎么直接的由A变到B,事实上,可以有中间桥梁连接A ...

  3. UVALive 4394 String painter

    题目大意:有两个字符串A,B,一次刷可以把A串一段刷成同一个字母,问至少要刷几次才能把A串变成B串.串长≤100. 本来以为是个很简单的区间DP,后来发现直接区间DP是不行的,这玩意有后效性:刷完一整 ...

  4. HDU2476:String painter(区间dp)

    原文地址:http://blog.csdn.net/a601025382s/article/details/12379565 原文作者:knownothing String painter Time ...

  5. ACM学习历程—HDU2476 String painter(动态规划)

    http://acm.hdu.edu.cn/showproblem.php?pid=2476 题目大意是给定一个起始串和一个目标串,然后每次可以将某一段区间染成一种字符,问从起始串到目标串最少需要染多 ...

  6. HDU-2476 String painter 区间DP

    题意:给你一个长度相等的A串和B串,每次可以把一个连续的区间刷成一个字母,问从A串到B串的最少操作数. 解法:虽然这类题一看到就知道是区间DP,但是之前只做过类似从空串变成某个串的题目,所以没想到怎么 ...

  7. HDU 2476 String painter (区间DP)

    题意:给出两个串a和b,一次只能将一个区间刷一次,问最少几次能让a=b 思路:首先考虑最坏的情况,就是先将一个空白字符串刷成b需要的次数,直接区间DP[i][j]表示i到j的最小次数. 再考虑把a变成 ...

  8. UVALive 4394 String painter——dp

    设ans[i]为区间[1,i]已经染好的最小花费 若s[i]=t[i],ans[i]=ans[i-1] 否则ans[i]=min{ans[j-1]+cost(j,i)},cost(j,i)为区间[j, ...

  9. LA 4394 String painter 区间DP -

    题目地址:http://vjudge.net/problem/UVALive-4394 很明显的区间DP 区间DP的套路就是 d[i][j]的在区间 (i,j) 刷的次数 转移也一般是 d[i][j] ...

最新文章

  1. 微软私有云分享(R2)5-域升级造成Hyper-V主机无法实时迁移
  2. 在GridView中针对鼠标单击的某一独立单元格进行编辑
  3. 职业生涯的8种德---非常重要
  4. java和C++的区别
  5. 用python前端html后端django_浅谈Django前端后端值传递问题
  6. myeclipse创建项目 我们的第一个代码
  7. 为什么还有那么多人用SVN?
  8. 62.Linux/Unix 系统编程手册(下) -- 终端
  9. 如何设置eclipse眼睛保护色-码农必备
  10. 高标清上下变换器的测试评估及应用研究
  11. 安防监控系统的几个基础小知识
  12. 服务器2t内存只显示1t,内存时序1t和2t的差别
  13. 微信小程序 公证号 根据code获取openid
  14. Ftp客户端-C#程序
  15. Canvas彩色樱花图案背景js特效
  16. 在线apt-get安装mysql_apt-get安装mysql
  17. 录音转成文字的方法分享
  18. icloud 如何同步_如何使用iCloud同步联系人,提醒等
  19. 数据库的锁机制理解和运用
  20. 加速你的安卓模拟器,让开发更迅速

热门文章

  1. HTML基础知识点(2)——常用标签
  2. 灰色预测模型matlab_Matlab数据分析,2020研究生报名人数灰色预测
  3. rsa前后端加密流程_不懂前后端分离?这篇就够了
  4. java executequery_java execute、executeQuery和executeUpdate之间的区别
  5. c++date数据类型_PLC编程设涉及到的数据类型了解一下
  6. sql server查询某一字段不重复的数据_初识数据库
  7. python cmath模块_python中math模块常用的方法整理
  8. TensorFlow学习笔记01:图
  9. 【BZOJ3437】小P的牧场,斜率优化DP
  10. 全国计算机考试一级在线模拟,2017全国计算机一级考试模拟