当前位置: 首页 > news >正文

BZOJ 1264: [AHOI2006]基因匹配Match( LCS )

序列最大长度2w * 5 = 10w, O(n²)的LCS会T.. 

LCS 只有当a[i] == b[j]时, 才能更新答案, 我们可以记录n个数在第一个序列中出现的5个位置, 然后从左往右扫第二个序列时将第一个序列对应位置的值更新, 用树状数组维护. 时间复杂度O(nlogn) 

-------------------------------------------------------------------------------------------------

#include<bits/stdc++.h>
   
#define rep(i, n) for(int i = 0; i < n; i++)
#define clr(x, c) memset(x, c, sizeof(x))
#define lowbit(x) ((x) & (-(x)))
 
using namespace std;
 
const int maxn = 20009, maxlen = 100009;
 
vector<int> pos[maxn];
int dp[maxlen], n, len;
 
void modify(int p, int v) {
for(; p <= len; p += lowbit(p))
   dp[p] = max(dp[p], v);
}
 
int query(int p) {
int ans = 0;
for(; p; p -= lowbit(p))
   ans = max(ans, dp[p]);
return ans;
}
 
int main() {
freopen("test.in", "r", stdin);
clr(dp, 0);
cin >> n;
len = n * 5;
rep(i, len) {
int v;
scanf("%d", &v);
pos[v].push_back(i + 1);
}
rep(i, len) {
int v;
scanf("%d", &v);
for(int j = 4; ~j; j--) {
int p = pos[v][j];
modify(p, query(p - 1) + 1);
}
}
cout << query(len) << "\n";
return 0;
}

-------------------------------------------------------------------------------------------------

1264: [AHOI2006]基因匹配Match

Time Limit: 10 Sec   Memory Limit: 162 MB
Submit: 700   Solved: 445
[ Submit][ Status][ Discuss]

Description

基因匹配(match) 卡卡昨天晚上做梦梦见他和可可来到了另外一个星球,这个星球上生物的DNA序列由无数种碱基排列而成(地球上只有4种),而更奇怪的是,组成DNA序列的每一种碱基在该序列中正好出现5次!这样如果一个DNA序列有N种不同的碱基构成,那么它的长度一定是5N。 卡卡醒来后向可可叙述了这个奇怪的梦,而可可这些日子正在研究生物信息学中的基因匹配问题,于是他决定为这个奇怪星球上的生物写一个简单的DNA匹配程序。 为了描述基因匹配的原理,我们需要先定义子序列的概念:若从一个DNA序列(字符串)s中任意抽取一些碱基(字符),将它们仍按在s中的顺序排列成一个新串u,则称u是s的一个子序列。对于两个DNA序列s1和s2,如果存在一个序列u同时成为s1和s2的子序列,则称u是s1和s2的公共子序列。 卡卡已知两个DNA序列s1和s2,求s1和s2的最大匹配就是指s1和s2最长公共子序列的长度。 [任务] 编写一个程序:  从输入文件中读入两个等长的DNA序列;  计算它们的最大匹配;  向输出文件打印你得到的结果。

Input

输入文件中第一行有一个整数N,表示这个星球上某种生物使用了N种不同的碱基,以后将它们编号为1…N的整数。 以下还有两行,每行描述一个DNA序列:包含5N个1…N的整数,且每一个整数在对应的序列中正好出现5次。

Output

输出文件中只有一个整数,即两个DNA序列的最大匹配数目。

Sample Input

2
1 1 2 2 1 1 2 1 2 2
1 2 2 2 1 1 2 2 1 1

Sample Output

7

HINT

[数据约束和评分方法]
60%的测试数据中:1<=N <= 1 000
100%的测试数据中:1<=N <= 20 000

Source

 

转载于:https://www.cnblogs.com/JSZX11556/p/4668318.html

相关文章:

  • 用Linux命令对两个文件进行连接操作
  • 一、小按钮和下面板---调试面板
  • memcached全面剖析–5. memcached的应用和兼容程序
  • 常见浏览器的兼容问题
  • 如何解决“不能打开数据库,用户NT AUTHORITY\NETWORK SERVICE登录失败”的错误呢?...
  • 基于vitamio的网络电视直播源码
  • Unity3D 导出apk 在真机调试时, 使用光贴图的模型丢失材质的BUG
  • 将C盘一个文本文件复制到D盘。
  • UVALive 6322 最大匹配...
  • 模板方法模式
  • Android Studio 简单介绍和使用问题小结
  • Redis内存存储结构分析
  • 数组删除空缺时的多余逗号
  • 图片验证
  • JDBC加载过程
  • 3.7、@ResponseBody 和 @RestController
  • android百种动画侧滑库、步骤视图、TextView效果、社交、搜房、K线图等源码
  • ComponentOne 2017 V2版本正式发布
  • java概述
  • JS笔记四:作用域、变量(函数)提升
  • PHP 小技巧
  • PHP变量
  • springboot_database项目介绍
  • 对象管理器(defineProperty)学习笔记
  • 高性能JavaScript阅读简记(三)
  • 后端_ThinkPHP5
  • 开源地图数据可视化库——mapnik
  • 聊聊hikari连接池的leakDetectionThreshold
  • 使用docker-compose进行多节点部署
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • ​软考-高级-系统架构设计师教程(清华第2版)【第15章 面向服务架构设计理论与实践(P527~554)-思维导图】​
  • # Java NIO(一)FileChannel
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (4) openssl rsa/pkey(查看私钥、从私钥中提取公钥、查看公钥)
  • (附源码)springboot电竞专题网站 毕业设计 641314
  • (附源码)ssm本科教学合格评估管理系统 毕业设计 180916
  • (每日持续更新)jdk api之FileFilter基础、应用、实战
  • (五)关系数据库标准语言SQL
  • (转)Spring4.2.5+Hibernate4.3.11+Struts1.3.8集成方案一
  • ***php进行支付宝开发中return_url和notify_url的区别分析
  • ***测试-HTTP方法
  • .axf 转化 .bin文件 的方法
  • .NET Compact Framework 多线程环境下的UI异步刷新
  • .net core webapi 大文件上传到wwwroot文件夹
  • .NET关于 跳过SSL中遇到的问题
  • .NET开发不可不知、不可不用的辅助类(三)(报表导出---终结版)
  • .NET面试题(二)
  • @javax.ws.rs Webservice注解
  • @RequestMapping处理请求异常
  • @WebServiceClient注解,wsdlLocation 可配置
  • [AAuto]给百宝箱增加娱乐功能
  • [Angular] 笔记 18:Angular Router
  • [C#]科学计数法(scientific notation)显示为正常数字
  • [Golang]K-V存储引擎的学习 从零实现 (RoseDB mini版本)
  • [HeadFrist-HTMLCSS学习笔记][第一章Web语言:开始了解HTML]