#6250. 「CodePlus 2017 11 月赛」找爸爸

题目描述

小 A 最近一直在找自己的爸爸,用什么办法呢,就是 DNA 比对。

小 A 有一套自己的 DNA 序列比较方法,其最终目标是最大化两个 DNA 序列的相似程度,具体步骤如下:

  1. 给出两个 DNA 序列,第一个长度为 nnn,第二个长度为 mmm。
  2. 在两个序列的任意位置插入任意多的空格,使得两个字符串长度相同。
  3. 逐位进行匹配,如果两个序列相同位置上的字符都不是空格,假设第一个是 xxx,第二个是 yyy,那么他们的相似程度由 d(x,y)d(x,y)d(x,y) 定义。对于两个序列中任意一段极长的长度为 kkk的连续空格,我们定义这段空格的相似程度为 g(k)=−A−B(k−1)g(k)=-A-B(k-1)g(k)=−A−B(k−1)。

那么最终两个序列的相似程度就是所有的 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} 四种字符。

测试点编号 n+mn + mn+m 的范围 特殊约定
1 n=m=1n = m = 1n=m=1 无特殊要求
2 n+m≤15n + m \leq 15n+m≤15
3 n+m≤300n + m \leq 300n+m≤300
4
5 n+m≤3000n + m \leq 3000n+m≤3000 序列中只包含一种字符
6 无特殊要求
7
8
9
10

来自 CodePlus 2017 11 月赛,清华大学计算机科学与技术系学生算法与竞赛协会 荣誉出品。
Credit:idea/邢健开 命题/邢健开 验题/陈宇
Git Repo:https://git.thusaac.org/publish/CodePlus201711
感谢腾讯公司对此次比赛的支持。

#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 1010
using namespace std;
char s1[maxn],s2[maxn];
int l1,l2,A,B,a[maxn],b[maxn],d[][];
void work1(){
int ans=d[a[]][b[]];
ans=max(ans,-A);
printf("%d",ans);
}
int main(){
scanf("%s%s",s1+,s2+);
l1=strlen(s1+);l2=strlen(s2+);
for(int i=;i<=l1;i++){
if(s1[i]=='A')a[i]=;
if(s1[i]=='T')a[i]=;
if(s1[i]=='G')a[i]=;
if(s1[i]=='C')a[i]=;
}
for(int i=;i<=l2;i++){
if(s2[i]=='A')b[i]=;
if(s2[i]=='T')b[i]=;
if(s2[i]=='G')b[i]=;
if(s2[i]=='C')b[i]=;
}
for(int i=;i<=;i++)
for(int j=;j<=;j++)
scanf("%d",&d[i][j]);
scanf("%d%d",&A,&B);
if(l1==l2&&l1==){work1();return ;}
}

10分 手玩

#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 3010
using namespace std;
char s1[maxn],s2[maxn];
int n,m,A,B,a[maxn],b[maxn],d[][],f[maxn][maxn][][];
void work(){
memset(f,-0x3f,sizeof(f));
f[][][][]=;
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
if(i==j&&j==)continue;
if(i&&j){
f[i][j][][]=max(f[i][j][][],f[i-][j-][][]+d[a[i]][b[j]]);
f[i][j][][]=max(f[i][j][][],f[i-][j-][][]+d[a[i]][b[j]]);
f[i][j][][]=max(f[i][j][][],f[i-][j-][][]+d[a[i]][b[j]]);
}
if(i){
f[i][j][][]=max(f[i][j][][],f[i-][j][][]-B);
f[i][j][][]=max(f[i][j][][],f[i-][j][][]-A);
f[i][j][][]=max(f[i][j][][],f[i-][j][][]-A);
}
if(j){
f[i][j][][]=max(f[i][j][][],f[i][j-][][]-B);
f[i][j][][]=max(f[i][j][][],f[i][j-][][]-A);
f[i][j][][]=max(f[i][j][][],f[i][j-][][]-A);
}
}
}
}
int main(){
scanf("%s%s",s1+,s2+);
n=strlen(s1+);m=strlen(s2+);
for(int i=;i<=n;i++){
if(s1[i]=='A')a[i]=;
if(s1[i]=='T')a[i]=;
if(s1[i]=='G')a[i]=;
if(s1[i]=='C')a[i]=;
}
for(int i=;i<=m;i++){
if(s2[i]=='A')b[i]=;
if(s2[i]=='T')b[i]=;
if(s2[i]=='G')b[i]=;
if(s2[i]=='C')b[i]=;
}
for(int i=;i<=;i++)
for(int j=;j<=;j++)
scanf("%d",&d[i][j]);
scanf("%d%d",&A,&B);
work();
int ans=max(f[n][m][][],max(f[n][m][][],f[n][m][][]));
printf("%d",ans);
return ;
}

100分 动态规划

 

loj #6250. 「CodePlus 2017 11 月赛」找爸爸的更多相关文章

  1. [LOJ 6249]「CodePlus 2017 11 月赛」汀博尔

    Description 有 n 棵树,初始时每棵树的高度为 H_i,第 i 棵树每月都会长高 A_i.现在有个木料长度总量为 S 的订单,客户要求每块木料的长度不能小于 L,而且木料必须是整棵树(即不 ...

  2. [LOJ 6248]「CodePlus 2017 11 月赛」晨跑

    Description “无体育,不清华”.“每天锻炼一小时,健康工作五十年,幸福生活一辈子” 在清华,体育运动绝对是同学们生活中不可或缺的一部分.为了响应学校的号召,模范好学生王队长决定坚持晨跑.不 ...

  3. [LOJ#6259]「CodePlus 2017 12 月赛」白金元首与独舞

    [LOJ#6259]「CodePlus 2017 12 月赛」白金元首与独舞 试题描述 到河北省 见斯大林 / 在月光下 你的背影 / 让我们一起跳舞吧 うそだよ~ 河北省怎么可能有 Stalin. ...

  4. LOJ6252. 「CodePlus 2017 11 月赛」大吉大利,晚上吃鸡! 最短路+bitset

    题目传送门 https://loj.ac/problem/6252 https://lydsy.com/JudgeOnline/problem.php?id=5109 题解 首先跑最短路,只保留 \( ...

  5. 「CodePlus 2017 11 月赛」Yazid 的新生舞会(树状数组/线段树)

    学习了新姿势..(一直看不懂大爷的代码卡了好久T T 首先数字范围那么小可以考虑枚举众数来计算答案,设当前枚举到$x$,$s_i$为前$i$个数中$x$的出现次数,则满足$2*s_r-r > 2 ...

  6. 「CodePlus 2017 11 月赛」大吉大利,晚上吃鸡!(dij+bitset)

    从S出发跑dij,从T出发跑dij,顺便最短路计数. 令$F(x)$为$S$到$T$最短路经过$x$的方案数,显然这个是可以用$S$到$x$的方案数乘$T$到$x$的方案数来得到. 然后第一个条件就变 ...

  7. 「CodePlus 2017 11 月赛」可做题

    这种题先二进制拆位,显然改的位置只有每一段确定的数的开头和结尾,只需要对于每一个可决策位置都尝试一下填1和0,然后取min即可. #include<iostream> #include&l ...

  8. 「CodePlus 2017 11 月赛」Yazid 的新生舞会

    n<=500000的数字,问有多少个区间的众数出现次数严格大于区间长度的一半. 这么说来一个区间就一个众数了,所以第一反应是枚举数字,对下标进行处理.然后没有第二反应.很好. 在枚举一个数字的时 ...

  9. 「CodePlus 2017 11 月赛」大吉大利,晚上吃鸡!

    n<=50000,m<=50000的图,给s和t,问有多少点对$(a,b)$满足 嗯. 不会. 首先最短路DAG造出来,然后两个条件转述一下:条件一,$N_a$表示从s到t经过a的路径,$ ...

随机推荐

  1. [转载]PCI/PCIe基础——配置空间

    转载地址:http://blog.csdn.net/jiangwei0512/article/details/51603525 PCI/PCIe设备有自己的独立地址空间,这部分空间会映射到整个系统的地 ...

  2. java代码。。重温JPassword,JLabel,JPanel

    package com.kk; //JPasswordField类的使用 import java.awt.Color; import java.awt.FlowLayout; import javax ...

  3. Regexp:template

    ylbtech-Regexp: 1.返回顶部 1.   2. 2.返回顶部   3.返回顶部   4.返回顶部   5.返回顶部     6.返回顶部   7.返回顶部   8.返回顶部   9.返回 ...

  4. ARRINC424—MORA(GRID)格式

    每一整数经.纬度为一格,每格MORA值3位数字,表示百英尺.无法获知MORA值得网格一UNK表示. 经纬网格起始点坐标,每个网格从左下角开始计数,每经纬度一度切分一个网格.每行数据代表某一维度上往东或 ...

  5. IRedisClient

    事实上,IRedisClient里面的很多方法,其实就是Redis的命令名.只要对Redis的命令熟悉一点就能够非常快速地理解和掌握这些方法,趁着现在对Redis不是特别了解,我也对着命令来了解一下这 ...

  6. 问题:Oracle出发器;结果:1、Oracle触发器详解,2、Oracle触发器示例

    ORACLE触发器详解 本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8.2.2 创 ...

  7. DAY10-MYSQL初识

    一 数据库管理软件的由来 基于我们之前所学,数据要想永久保存,都是保存于文件中,毫无疑问,一个文件仅仅只能存在于某一台机器上. 如果我们暂且忽略直接基于文件来存取数据的效率问题,并且假设程序所有的组件 ...

  8. linux&nbsp;dev/dsp&nbsp;声卡学习笔记

    原文地址:dev/dsp 声卡学习笔记">linux dev/dsp 声卡学习笔记作者:ziyou飞翔       无论是从声卡读取数据,或是向声卡写入数据,事实上都具有特定的格式(f ...

  9. C++知识点总结(5)

    1.为何静态成员函数不能调用非静态成员函数 静态成员函数可以不需要类的实例就直接使用,非静态的成员函数很可能用到一些成员变量,而成员变量的创建和初始化是在创建了类的实例时在构造函数调用的时候才进行的. ...

  10. Android广播接收者

    其实,在什么是广播的第一句就已经说明了广播有什么用了.对了,笼统一点讲就是用来传输数据的.具体一点说就是:1. 实现了不同的程序之间的数据传输与共享,因为只要是和发送广播的action相同的接受者都能 ...