- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563365 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174232
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
+ ?# R3 F& @$ b
2019第十届蓝桥杯B组决赛题解第六题
) k" z: \2 {. e' A, H* g题意:输入一个S串和一个T串,|S|>= |T|,问最少要修改S中的几个字母才能使S中有子序列T
) Q8 e/ `) I) J( o+ l" R* g( O5 P9 o4 ~ w! n5 e
思路:dp+贪心" J+ U& v# f9 R0 W
* f# V" d% s7 d, Y2 R/ o
f[j]表示以S中第i个字母开头的串包含T中第j个字母开头的串所要修改的最少的字母数,* i. @, r( u, w
即S中i之前的字母已经包含T中j之前所有的字母,所以分别从i和j位置继续匹配
1 i: ^/ W1 t. t7 i% E m
& h3 P2 t8 M5 J) e: k过程简述如下:: H R- g$ H6 }% _/ j
S: ABCECDFF0 N. B) O$ R! [% m4 M
T: BBDEC
" d$ Y7 X, o- D0 w4 _% F4 i) ?" m) x3 I" Z3 e4 l3 J4 ~
开始i=1,j=1( i1 t Z0 N: H! j+ b' T& Q- m
在S开始寻找T[j]即'B',在i=2位置找到,此时我们面临两个选择,要么就让i=2和j=1匹配,要么就修改i=1的'A'为'B',因为既然修改肯定就修改最前面的
" C& _( F7 `# d6 u/ N假如选了前者,接下来就从i=3,j=2继续匹配,假如选了后者,就从i=2,j=2继续匹配,无论怎么选,后面面临的子问题和刚才面临的问题一模一样+ M) j" Z" g& c T8 d9 B+ _' @
对于这个样例,选择后者总共只需要修改2个S中的字母,选择前者总共需要修改3个S中的字母
, [- o9 d2 L( [ ?2 l! ?2 b- c5 N( N# [( r k( j
本题我们需要预处理使得我们可以O(1)的查询到1位置后面最近的'B'在哪里,预处理见代码
* f% C; ~* r" y9 ^% i) l/ E还需要把f[j]记录清楚,因为有很多重复的子问题我们没有必要重复计算3 z( _2 _0 z8 e. {6 {
8 U9 e0 h4 i# F代码:2 v+ q( K0 P6 ]- i. Y
---------------------
! s6 @; T5 ?# C o' ?5 W% y作者:nka_kun
) }% ]! F( V6 U! [# U来源:CSDN
4 `+ \$ Q4 X* y4 l# {9 \ j, Q1 P5 k* S- f3 O Y2 {) a
8 W4 U) P) l" f0 U% U
6 h. I& V. t- Y |
zan
|