小 A 最近一直在找自己的爸爸,用什么办法呢,就是 DNA 比对。
小 A 有一套自己的 DNA 序列比较方法,其最终目标是最大化两个 DNA 序列的相似程度,具体步骤如下:
那么最终两个序列的相似程度就是所有的 d(x,y)d(x,y)d(x,y) 加上所有的极长空格段的相似程度之和。
现在小 A 通过某种奥妙重重的方式得到了小 B 的 DNA 序列中的一段,他想请你帮他算一下小 A 的 DNA 序列和小 B 的 DNA 序列的最大相似程度。
输入第 111 行一个字符串,表示小 A 的 DNA 序列。
输入第 222 行一个字符串,表示小 B 的 DNA 序列。
接下来 444 行,每行 444 个整数,用空格隔开,表示 ddd 数组,具体顺序如下所示。
d(A,A)d(A,A)d(A,A) d(A,T)d(A,T)d(A,T) d(A,G)d(A,G)d(A,G) d(A,C)d(A,C)d(A,C)d(T,A)d(T,A)d(T,A) d(T,T)d(T,T)d(T,T) d(T,G)d(T,G)d(T,G) d(T,C)d(T,C)d(T,C)d(G,A)d(G,A)d(G,A) d(G,T)d(G,T)d(G,T) d(G,G)d(G,G)d(G,G) d(G,C)d(G,C)d(G,C)d(C,A)d(C,A)d(C,A) d(C,T)d(C,T)d(C,T) d(C,G)d(C,G)d(C,G) d(C,C)d(C,C)d(C,C)
最后一行两个用空格隔开的正整数 A,BA,BA,B,意义如题中所述。
输出共一行,表示两个序列的最大相似程度。
ATGG ATCC 5 -4 -4 -4 -4 5 -4 -4 -4 -4 5 -4 -4 -4 -4 5 2 1
4
首先,将序列补成如下形式(- 代表空格)
-
ATGG-- AT--CC
然后所有 d(x,y)d(x,y)d(x,y) 的和为 d(A,A)+d(T,T)=10d(A,A)+d(T,T)=10d(A,A)+d(T,T)=10,所有极长连续空格段的相似程度之和为 g(2)+g(2)=−6g(2)+g(2)=-6g(2)+g(2)=−6。总和为 444,可以验证,这是相似程度最大的情况。
对于所有测试点,有 0<B<A≤1000,−1000≤d(x,y)≤1000,d(x,y)=d(y,x)0< B<A \le 1000, -1000\le d(x,y)\le 1000,d(x,y)=d(y,x)0<B<A≤1000,−1000≤d(x,y)≤1000,d(x,y)=d(y,x),序列只包含 {A,T,G,C}\{\text{A},\text{T},\text{G},\text{C}\}{A,T,G,C} 四种字符。
来自 CodePlus 2017 11 月赛,清华大学计算机科学与技术系学生算法与竞赛协会 荣誉出品。Credit:idea/邢健开 命题/邢健开 验题/陈宇Git Repo:https://git.thusaac.org/publish/CodePlus201711感谢腾讯公司对此次比赛的支持。