BZOJ2764 [JLOI2011]基因补全
Description
Input
Output
Sample Input
CTAGTAGAAG
TCC
Sample Output
HINT
样例解释:
TCC的4种补全方案(括号中字符为补全的碱基)
(GA)TC(AT)C(TTC)
(GA)TC(ATCTT)C
(GA)T(CAT)C(TT)C
(GATCA)TC(TT)C
数据范围:
30%数据n<=1000,m<=2
50%数据n<=1000,m<=4
100%数据n<=2000,m<=n
正解:DP+高精度
解题报告:
好久没写题了,感觉只要不是考试就写不动题了。。。
这道题其实挺水的,就是一个编辑距离。考虑f[i][j]表示长串匹配到i,短串匹配到j的方案数,显然对于长串而言,我们需要在短串的对应位置补一些新的数字才行。所以f[i][j]=f[i-1][j]表示i这一位上与之相对应的短串上填一个新的数字,并且如果a[i]与b[j]能匹配,那么f[i][j]+=f[i-1][j-1];表示各匹配一位。
因为答案很大,所以要写高精度。还要滚动数组。
//It is made by jump~
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <ctime>
#include <vector>
#include <queue>
#include <map>
#include <set>
#ifdef WIN32
#define OT "%I64d"
#else
#define OT "%lld"
#endif
using namespace std;
typedef long long LL;
const int MAXN = ;
const int MOD = ;
int n,m;
int match[],a[MAXN],b[MAXN];
//int f[MAXN][MAXN][10];//f[i][j]表示长串匹配到i,短串匹配到j的方案数,滚动数组
//int cnt[MAXN][MAXN];
int cnt[MAXN];
int f[MAXN][]; inline int getint()
{
int w=,q=;
char c=getchar();
while((c<'' || c>'') && c!='-') c=getchar();
if (c=='-') q=, c=getchar();
while (c>='' && c<='') w=w*+c-'', c=getchar();
return q ? -w : w;
}
/*
inline void add(int x,int y,int i,int j){
int now=1;
if(cnt[x][y]<cnt[i][j]) cnt[x][y]=cnt[i][j];
while(now<=cnt[x][y]) {
f[x][y][now]+=f[i][j][now]; now++;
}
for(int i=1;i<=cnt[x][y];i++)
if(f[x][y][i]>=MOD)
f[x][y][i+1]+=f[x][y][i]/MOD,f[x][y][i]%=MOD;
while(f[x][y][cnt[x][y]+1]) cnt[x][y]++;
}*/ inline void work(){
n=getint(); m=getint(); char c;
match[]=; match[]=; match[]=; match[]=;
for(int i=;i<=n;i++) {
c=getchar();
while(c<'A' || c>'T') c=getchar();
if(c=='A') a[i]=; else if(c=='C') a[i]=; else if(c=='T') a[i]=; else a[i]=;
}
for(int i=;i<=m;i++) {
c=getchar();
while(c<'A' || c>'T') c=getchar();
if(c=='A') b[i]=; else if(c=='C') b[i]=; else if(c=='T') b[i]=; else b[i]=;
} f[][]=; cnt[]=;
for(int i=;i<=m;i++) cnt[i]=;
for(int i=;i<=n;i++)
for(int j=m;j>=;j--) {
if(match[a[i]]!=b[j]) continue;
if(cnt[j]<cnt[j-]) cnt[j]=cnt[j-];
for(int l=;l<=cnt[j];l++) {
f[j][l]+=f[j-][l];
if(f[j][l]>=MOD) f[j][l+]+=f[j][l]/MOD,f[j][l]%=MOD;
}
while(f[j][cnt[j]+]) cnt[j]++;
}
printf("%d",f[m][cnt[m]]);
for(int i=cnt[m]-;i>=;i--) printf("%08d",f[m][i]);
/*
for(int i=0;i<=n;i++) for(int j=0;j<=m;j++) cnt[i][j]=1;
for(int i=0;i<=n;i++) f[i][0][1]=1;
for(int i=1;i<=n;i++)
for(int j=m;j>=1;j--) {
if(cnt[i][j]<cnt[i-1][j])cnt[i][j]=cnt[i-1][j];
for(int l=1;l<=cnt[i-1][j];l++) f[i][j][l]=f[i-1][j][l]; //一位新添加一个数
if(match[a[i]]==b[j]){
add(i,j,i-1,j-1);//由上一位转移过来
}
}
printf("%d",f[n][m][cnt[n][m]]);
for(int i=cnt[n][m]-1;i>=1;i--) printf("%08d",f[n][m][i]);*/
} int main()
{
work();
return ;
}
BZOJ2764 [JLOI2011]基因补全的更多相关文章
- 2764: [JLOI2011]基因补全
2764: [JLOI2011]基因补全 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 570 Solved: 187[Submit][Status ...
- [JLOI2011]基因补全
1973: [JLOI2011]基因补全 Time Limit: 1 Sec Memory Limit: 256 MB Description 在生物课中我们学过,碱基组成了DNA(脱氧核糖核酸), ...
- BZOJ_2764_[JLOI2011]基因补全_DP_高精度
BZOJ_2764_[JLOI2011]基因补全_DP_高精度 Description 在生物课中我们学过,碱基组成了DNA(脱氧核糖核酸),他们分别可以用大写字母A,C,T,G表示,其中A总与T配对 ...
- 【bzoj2764】[JLOI2011]基因补全 dp+高精度
题目描述 在生物课中我们学过,碱基组成了DNA(脱氧核糖核酸),他们分别可以用大写字母A,C,T,G表示,其中A总与T配对,C总与G配对.两个碱基序列能相互匹配,当且仅当它们等长,并且任意相同位置的碱 ...
- bzoj2764 基因补全
Description 在生物课中我们学过,碱基组成了DNA(脱氧核糖核酸),他们分别可以用大写字母A,C,T,G表示,其中A总与T配对,C总与G配对.两个碱基序列能相互匹配,当且仅当它们等长,并且任 ...
- Oracle补全日志(Supplemental logging)
Oracle补全日志(Supplemental logging)特性因其作用的不同可分为以下几种:最小(Minimal),支持所有字段(all),支持主键(primary key),支持唯一键(uni ...
- python 添加tab补全
在平时查看Python方法用到tab补全还是很方便的. 1. mac 平台 配置如下: mac是类Unix平台,需要在添加一条配置内容到bash_profile 中(默认是没有这个文件,可以新建一个放 ...
- 记录一次bug解决过程:else未补全导致数据泄露和代码优化
一.总结 快捷键ctrl + alt + 四个方向键 --> 倒置屏幕 未补全else逻辑,倒置查询数据泄露 空指针是最容易犯的错误,数据的空指针,可以普遍采用三目运算符来解决 SVN冲突解决关 ...
- jQuery 邮箱下拉列表自动补全
综述 我想大家一定见到过,在某个网站填写邮箱的时候,还没有填写完,就会出现一系列下拉列表,帮你自动补全邮箱的功能.现在我们就用jQuery来实现一下. 博主原创代码,如有代码写的不完善的地方还望大家多 ...
随机推荐
- JavaScript数据结构与算法-列表练习
实现列表类 // 列表类 function List () { this.listSize = 0; // 列表的元素个数 this.pos = 0; // 列表的当前位置 this.dataStor ...
- 【转】Linux系统上安装MySQL 5.5 rpm
1.准备工作 从MySQL官网上分别下载mysql服务器端于客户端包. 如: MySQL-server-5.5.15-1.linux2.6.x86_64.rpm和MySQL-client-5.5.15 ...
- python实现复制整个目录的方法
import shutil #复制文件 shutil.copyfile('listfile.py', 'd:/test.py') #复制目录 shutil.copytree('d:/temp', 'c ...
- 我的Android进阶之旅------>【强力推荐】Android开源图表库XCL-Charts版本发布及展示页
因为要做图表相关的应用,后来百度发现了一个很好的Android开源图表库(XCL-Charts is a free charting library for Android platform.) 下面 ...
- PAT 1071. 小赌怡情(15) JAVA
1071. 小赌怡情(15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 常言道“小赌怡情”.这是一个很简单的 ...
- linux 安装zip/unzip/g++/gdb/vi/vim等软件
近期公司新配置了一台64位云server.去部署的时候发现,没有安装zip/unzip压缩解压软件. 于是仅仅好自己安装这两个软件.linux最好用的还是yum. 两个指令就安装好了. 首先把软件安装 ...
- Python多进程multiprocessing
import multiprocessing import time # 具体的处理函数,负责处理单个任务 def func(msg): # for i in range(3): print (msg ...
- 测试开发面试的Linux面试题:常用命令
Hello,大家好上次给大家介绍了vim使用方法,今天来给大家讲一讲linux系统文件命令 (1)Linux的文件系统目录配置要遵循FHS规范,规范定义的两级目录规范如下: /home ...
- nodejs post请求
const http = require('http'); const querystring = require('querystring'); const postData = querystri ...
- 开机提示memory size decreased怎么办?
ytkah的办公电脑实在是hold不住,win7用2G的内存,基本是在等待中度过的,没有新的只能考虑加格内存了,采购嘛,需走一大堆流程,跟领导请示从其他硬件需求不是很高的电脑那边拔一根内存条吧,小C的 ...