- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563314 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174217
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
7 {4 b9 b8 P# ]2 H0 K# F2019第十届蓝桥杯B组决赛题解第六题/ S$ u% i! r7 a
题意:输入一个S串和一个T串,|S|>= |T|,问最少要修改S中的几个字母才能使S中有子序列T
( G1 F* A9 O& {- h' N9 Z7 k2 z, p8 A: b+ x, H/ g% d
思路:dp+贪心, H4 j2 o+ ?: p( @
) R" }# `/ Q* q1 A7 hf[j]表示以S中第i个字母开头的串包含T中第j个字母开头的串所要修改的最少的字母数,
( u: d' ]( m2 f7 T/ b即S中i之前的字母已经包含T中j之前所有的字母,所以分别从i和j位置继续匹配
. V% W% u" ^" O+ {* H
/ L4 }0 y. ?' y1 q& P; U$ X p过程简述如下:8 A3 M! M; @$ Z
S: ABCECDFF
& d! U- z2 l# Q' ]- w* i) V- ET: BBDEC7 Z5 b# ]# m8 V2 x$ p: I1 w. e2 T
* s6 X5 m9 h8 g4 L
开始i=1,j=14 L, c" p. f& S. L/ w* o
在S开始寻找T[j]即'B',在i=2位置找到,此时我们面临两个选择,要么就让i=2和j=1匹配,要么就修改i=1的'A'为'B',因为既然修改肯定就修改最前面的" o! U. W g: l# |2 C
假如选了前者,接下来就从i=3,j=2继续匹配,假如选了后者,就从i=2,j=2继续匹配,无论怎么选,后面面临的子问题和刚才面临的问题一模一样# J( U3 B0 [- Z
对于这个样例,选择后者总共只需要修改2个S中的字母,选择前者总共需要修改3个S中的字母- u1 w# O& S- w1 W
$ k: F# r4 Y6 ] k6 [
本题我们需要预处理使得我们可以O(1)的查询到1位置后面最近的'B'在哪里,预处理见代码: s' x6 ]. W4 T- U: B% K3 \) U" w1 Y
还需要把f[j]记录清楚,因为有很多重复的子问题我们没有必要重复计算
; Q" J+ S6 p1 o
0 c. _2 ~6 a1 z, ^/ @代码:# t: M' I( v& k; f% C" Q
---------------------
) J- n/ Y3 V7 L' G' [作者:nka_kun
) ^& a0 G2 F, a2 a) k4 h0 I5 X! M来源:CSDN
[) c/ b6 W/ G5 D
( n a- W4 v" F# _0 g* t8 q1 P' g8 ^" w8 t7 {: C% z
' P+ J: H7 K+ z, Q8 u" S
|
zan
|