- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 564671 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174624
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
3 C. z" O1 V$ {/ j& e2019第十届蓝桥杯B组决赛题解第六题
$ \. O- I9 B3 V! W; w题意:输入一个S串和一个T串,|S|>= |T|,问最少要修改S中的几个字母才能使S中有子序列T( X) w) {0 ?6 @: Q6 y! e8 P" x
8 R# h# U/ K; v* @) P
思路:dp+贪心2 I k8 p6 S4 }) j7 y
0 I; @$ _- M0 {; I Y2 Y
f[j]表示以S中第i个字母开头的串包含T中第j个字母开头的串所要修改的最少的字母数,
' g& k4 D3 x2 [# n9 i( F即S中i之前的字母已经包含T中j之前所有的字母,所以分别从i和j位置继续匹配# I9 i( ]4 x; x
( Q& Y4 h7 _5 b( v; m) h$ |. s! o5 M* W
过程简述如下:# r3 B: e1 Y5 J/ o" X
S: ABCECDFF+ d4 O( x ]; j3 ?. ]' l
T: BBDEC
/ p% c# K" M) t1 f4 D. i4 _
+ [! s- b }9 M: W开始i=1,j=1
! c0 N3 |' s8 q3 V在S开始寻找T[j]即'B',在i=2位置找到,此时我们面临两个选择,要么就让i=2和j=1匹配,要么就修改i=1的'A'为'B',因为既然修改肯定就修改最前面的+ V8 _! n- i# ~- g
假如选了前者,接下来就从i=3,j=2继续匹配,假如选了后者,就从i=2,j=2继续匹配,无论怎么选,后面面临的子问题和刚才面临的问题一模一样7 X& n2 K1 Y6 t3 G- r. a" |
对于这个样例,选择后者总共只需要修改2个S中的字母,选择前者总共需要修改3个S中的字母, i( R7 K4 x" p+ k' X
* K! \+ f$ S4 U) ^- Y- D本题我们需要预处理使得我们可以O(1)的查询到1位置后面最近的'B'在哪里,预处理见代码
- E s6 r( b& `9 I* j% w/ c% z3 r还需要把f[j]记录清楚,因为有很多重复的子问题我们没有必要重复计算
( U0 F! F" a% O8 I1 m, ^; f# H* i# ^( Z, e' h
代码:1 ?: S5 q' |2 q/ @* d4 I
--------------------- , Y8 F" U6 j a/ F4 R+ H
作者:nka_kun
& U( _; {( A3 v来源:CSDN ) \2 S, T; a, A4 L3 W
8 D& E2 Y& h5 e" g# {+ b/ Z0 q6 c4 O3 f6 w: Q! E
& A7 O& Q0 d. M( z& Y( d |
zan
|