#P4303. [AHOI2006] 基因匹配

    ID: 5030 远端评测题 1000ms 125MiB 尝试: 0 已通过: 0 难度: 5 上传者: 标签>2006各省省选树状数组安徽背包 DP

[AHOI2006] 基因匹配

题目描述

卡卡昨天晚上做梦梦见他和可可来到了另外一个星球,这个星球上生物的 DNA 序列由无数种碱基排列而成(地球上只有 44 种),而更奇怪的是,组成 DNA 序列的每一种碱基在该序列中正好出现 55 次!这样如果一个 DNA 序列由 NN 种不同的碱基构成,那么它的长度一定是 5N5N

卡卡醒来后向可可叙述了这个奇怪的梦,而可可这些日子正在研究生物信息学中的基因匹配问题,于是他决定为这个奇怪星球上的生物写一个简单的 DNA 匹配程序。

为了描述基因匹配的原理,我们需要先定义子序列的概念:若从一个 DNA 序列(字符串)ss 中任意抽取一些碱基(字符),将它们仍按在s中的顺序排列成一个新串 uu,则称 uuss 的一个子序列。对于两个 DNA 序列 s1s_1s2s_2,如果存在一个序列 uu 同时成为 s1s_1s2s_2 的子序列,则称 uus1s_1s2s_2 的公共子序列。

卡卡已知两个 DNA 序列 s1s_1s2s_2,求 s1s_1s2s_2 的最大匹配就是指 s1s_1s2s_2 最长公共子序列的长度。

[任务] 编写一个程序:

  • 从输入文件中读入两个等长的 DNA 序列;
  • 计算它们的最大匹配;
  • 向输出文件打印你得到的结果。

输入格式

输入文件中第一行有一个整数 NN,表示这个星球上某种生物使用了 NN 种不同的碱基,以后将它们编号为 1N1…N 的整数。

以下还有两行,每行描述一个 DNA 序列:包含 5N5N1N1…N 的整数,且每一个整数在对应的序列中正好出现 55 次。

输出格式

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

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

8

提示

1N200001 \leq N \leq 20000