- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563318 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174218
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
) d! m2 A) s7 ^5 H2019第十届蓝桥杯B组决赛题解第六题
6 l" [- F0 c$ o+ z题意:输入一个S串和一个T串,|S|>= |T|,问最少要修改S中的几个字母才能使S中有子序列T
; Y. b3 w Z3 p( {- N Q! g3 N# E- D5 n5 x, l. n
思路:dp+贪心
5 F- d% I/ P1 d- g9 e) u* q/ y2 {) S/ j
f[j]表示以S中第i个字母开头的串包含T中第j个字母开头的串所要修改的最少的字母数,
7 h/ z) G0 u" j+ b9 P$ ~, \5 E即S中i之前的字母已经包含T中j之前所有的字母,所以分别从i和j位置继续匹配
, K6 J$ T+ D* H/ e, o
k, t) A! k& ~过程简述如下:
. y {+ Y' {- f+ j+ AS: ABCECDFF
6 D7 J5 ]8 F7 x( G/ oT: BBDEC
& m4 Y7 d+ B, S3 o; z' v" l8 P, ~4 }/ q" w! s' C8 w
开始i=1,j=1
& R( m* O. p, S# w, d在S开始寻找T[j]即'B',在i=2位置找到,此时我们面临两个选择,要么就让i=2和j=1匹配,要么就修改i=1的'A'为'B',因为既然修改肯定就修改最前面的
" c M$ z: h$ r3 i# d4 j+ n假如选了前者,接下来就从i=3,j=2继续匹配,假如选了后者,就从i=2,j=2继续匹配,无论怎么选,后面面临的子问题和刚才面临的问题一模一样/ B5 }4 {% {0 m- x
对于这个样例,选择后者总共只需要修改2个S中的字母,选择前者总共需要修改3个S中的字母" P1 L( Z- g( t& y/ ~
% R7 A# U- g# e$ G* W% v4 O- V
本题我们需要预处理使得我们可以O(1)的查询到1位置后面最近的'B'在哪里,预处理见代码; J8 X! o2 E4 Q! Y N
还需要把f[j]记录清楚,因为有很多重复的子问题我们没有必要重复计算
3 }' l: O0 p9 P; n, y/ f: g% l$ ?1 w' K G% h/ s5 n( ]5 u( C
代码:9 G$ y# L. \8 s2 a6 R
--------------------- 8 a& w0 J$ U3 ?8 v4 n, b
作者:nka_kun
0 n) \ N* e; D* @来源:CSDN
! n! C, m d; C2 F: i( G' J4 Z; M" ~ m6 h: F6 H9 q' x' t9 `6 w
% f% Q9 y5 B' U4 y6 k Z/ X8 O2 x" q2 j( x
|
zan
|