DP做题记录
P1140 相似基因
考虑如何设计状态。
设给出的两个串为串 \(A\) 和串 \(B\),长度分别为 \(n\) 和 \(m\)。
我们用 \(f[i][j]\) 来表示前 \(i\) 个 \(A\) 串碱基和前 \(j\) 个 \(B\) 串碱基得到的最大相似度。
我们因为求的是最大的相似度,而从题目给的表来看是可能为负的,所以先初始化一下 \(f[i][j]\) 数组。
那么我们就考虑到有三种转移的方式:
当前 \(A\) 串插入一个空碱基。
当前 \(B\) 串插入一个空碱基。
当前串不插入空碱基,直接进行相似度比对。
两个串都插入空碱基相当于没插入,所以不考虑。
我们知道一个空串和碱基序列的相似度就是相当于碱基序列都是和空碱基进行相似度比对,所以我们要进行一个小小的预处理。
code:
#include<bits/stdc++.h>
#define INF 0x3f3f3f3f
#define int long long
#define N 1010
using namespace std;
int n,m,f[N][N],a[N],b[N];
string s1,s2;
int mp[10][10]=
{
{5,-1,-2,-1,-3},
{-1,5,-3,-2,-4},
{-2,-3,5,-2,-2},
{-1,-2,-2,5,-1},
{-3,-4,-2,-1,0},
};
inline void init(int len,string a,int b[])
{
for(int i=1;i<=len;i++)
{
if(a[i-1]=='A')b[i]=0;
if(a[i-1]=='C')b[i]=1;
if(a[i-1]=='G')b[i]=2;
if(a[i-1]=='T')b[i]=3;
}
}
signed main()
{
cin>>n>>s1>>m>>s2;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
f[i][j]=-INF;//预处理
init(n,s1,a);
init(m,s2,b);
for(int i=1;i<=n;i++)f[i][0]=f[i-1][0]+mp[a[i]][4];//预处理
for(int i=1;i<=m;i++)f[0][i]=f[0][i-1]+mp[b[i]][4];
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
f[i][j]=max(f[i][j],f[i-1][j]+mp[a[i]][4]);//A串插入空碱基
f[i][j]=max(f[i][j],f[i][j-1]+mp[b[j]][4]);//B串插入空碱基
f[i][j]=max(f[i][j],f[i-1][j-1]+mp[a[i]][b[j]]);//不插入空碱基
}
}
cout<<f[n][m]<<endl;
return 0;
}
P1279 字串距离
一眼看去和上面那道题目一样,区别就是更好写了,因为加的值都能直接得出。
同样分三种情况转移。
code:
#include<bits/stdc++.h>
#define INF 0x3f3f3f3f
#define int long long
#define N 2010
using namespace std;
string s1,s2;
int n,m,k,f[N][N],a[N],b[N];
signed main()
{
cin>>s1>>s2>>k;
n=s1.size();
m=s2.size();
for(int i=1;i<=n;i++)a[i]=s1[i-1]-'a';//字符转数字方便计算,同时把下标从0开始改为从1开始
for(int i=1;i<=m;i++)b[i]=s2[i-1]-'a';
memset(f,INF,sizeof f);f[0][0]=0;//赋初值,f[0][0]特殊处理
for(int i=1;i<=n;i++)f[i][0]=f[i-1][0]+k;//预处理和空串匹配的距离
for(int i=1;i<=m;i++)f[0][i]=f[0][i-1]+k;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
f[i][j]=min(f[i][j],f[i-1][j]+k);//往j中插入空格
f[i][j]=min(f[i][j],f[i][j-1]+k);//往i中插入空格
f[i][j]=min(f[i][j],f[i-1][j-1]+abs(a[i]-b[j]));//不插入空格,直接计算两个字符的ascll码的差值
}
}
cout<<f[n][m]<<endl;
return 0;
}
DP做题记录的更多相关文章
- DP 做题记录 II.
里面会有一些数据结构优化 DP 的题目(如 XI.),以及普通 DP. *I. P3643 [APIO2016]划艇 题意简述:给出序列 \(a_i,b_i\),求出有多少序列 \(c_i\) 满足 ...
- Sam做题记录
Sam做题记录 Hihocoder 后缀自动机二·重复旋律5 求一个串中本质不同的子串数 显然,答案是 \(\sum len[i]-len[fa[i]]\) Hihocoder 后缀自动机三·重复旋律 ...
- 退役III次后做题记录(扯淡)
退役III次后做题记录(扯淡) CF607E Cross Sum 计算几何屎题 直接二分一下,算出每条线的位置然后算 注意相对位置这个不能先搞出坐标,直接算角度就行了,不然会卡精度/px flag:计 ...
- BJOI做题记录
BJOI做题记录 终于想起还要做一下历年省选题了2333 然而咕了的还是比做了的多2333 LOJ #2178. 「BJOI2017」机动训练 咕了. LOJ #2179. 「BJOI2017」树的难 ...
- DP刷题记录(持续更新)
DP刷题记录 (本文例题目前大多数都选自算法竞赛进阶指南) TYVJ1071 求两个序列的最长公共上升子序列 设\(f_{i,j}\)表示a中的\(1-i\)与b中色\(1-j\)匹配时所能构成的以\ ...
- UOJ 做题记录
UOJ 做题记录 其实我这么弱> >根本不会做题呢> > #21. [UR #1]缩进优化 其实想想还是一道非常丝播的题目呢> > 直接对于每个缩进长度统计一遍就好 ...
- project euler做题记录
ProjectEuler_做题记录 简单记录一下. problem 441 The inverse summation of coprime couples 神仙题.考虑答案为: \[\begin{a ...
- 退役IV次后做题记录
退役IV次后做题记录 我啥都不会了.... AGC023 D 如果所有的楼房都在\(S\)同一边可以直接得出答案. 否则考虑最左最右两边的票数,如果左边>=右边,那么最右边会投给左边,因为就算车 ...
- 退役II次后做题记录
退役II次后做题记录 感觉没啥好更的,咕. atcoder1219 历史研究 回滚莫队. [六省联考2017]组合数问题 我是傻逼 按照组合意义等价于\(nk\)个物品,选的物品\(\mod k\) ...
- FJOI2017前做题记录
FJOI2017前做题记录 2017-04-15 [ZJOI2017] 树状数组 问题转化后,变成区间随机将一个数异或一,询问两个位置的值相等的概率.(注意特判询问有一个区间的左端点为1的情况,因为题 ...
随机推荐
- Java开发词汇
Java基础常见英语词汇(70个) OO: object-oriented ,面向对象 OOP: object-oriented programming,面向对象编程 JDK:Java develop ...
- Java基础学习——Scanner
import java.util.Scanner; public class HelloWord{ public static void main(String[] args){ Scanner s= ...
- Matlab:4维、单目标、约束、粒子群优化算法
% 主调用函数(求最大值) clc; clear; close all; % 初始化种群 N = 100; % 初始种群个数 D = 4; % 空间维数 iter = 50; % 迭代次数 x_lim ...
- enobj.cn站有更新
1:整体样式 2:可以折叠app列表 3:手机端样式 4: Blog链接到博客园
- vlan概述
一.vlan是什么? vlan顾名思义就是虚拟局域网Virtual Local Area Network,为什么要划分vlan?划分vlan可以控制广播,增强网络安全性,简化网络管理. 二.vlan的 ...
- time命令详解
Linux中time命令,我们经常用来计算某个程序的运行耗时,用户态cpu耗时,系统态cpu耗时. 例如: $ time foo real 0m0.003s user 0m ...
- 钉钉回调事件-asp.net core 开发钉钉回调事件
最近有一个钉钉的项目,所以,接下来的日子里,我会把钉钉开发中遇到的问题都整理成博客,供大家参考. 钉钉开发者后台,添加好了小程序,需要提供一个回调URL地址,用于数据的同步.如下图 根据钉钉提供的de ...
- .net core mvc中session的应用
1.首先新建一个空的web项目,在Program.cs中打开和使用session public class Program { public static void Main(string[] arg ...
- 如何确定有价值的RPA场景
什么是RPA? RPA(Robotic Process Automation,机器人流程自动化)是通过特定的.可模拟人类在计算机界面上进行操作的技术,按规则自动执行相应的流程任务,代替或辅助人类完成相 ...
- MySQL学习(八)BLOB和TEXT区别
:都市为存储很大数据而设计的字符串数据类型,分别采用二进制和字符方式存储.当blob和text值太大时,innodb会使用专门的"外部"存储区域来进行存储,此时每个值在行内需要1~ ...