P1140 相似基因

考虑如何设计状态。

设给出的两个串为串 \(A\) 和串 \(B\),长度分别为 \(n\) 和 \(m\)。

我们用 \(f[i][j]\) 来表示前 \(i\) 个 \(A\) 串碱基和前 \(j\) 个 \(B\) 串碱基得到的最大相似度。

我们因为求的是最大的相似度,而从题目给的表来看是可能为负的,所以先初始化一下 \(f[i][j]\) 数组。

那么我们就考虑到有三种转移的方式:

  1. 当前 \(A\) 串插入一个空碱基。

  2. 当前 \(B\) 串插入一个空碱基。

  3. 当前串不插入空碱基,直接进行相似度比对。

两个串都插入空碱基相当于没插入,所以不考虑。

我们知道一个空串和碱基序列的相似度就是相当于碱基序列都是和空碱基进行相似度比对,所以我们要进行一个小小的预处理。

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做题记录的更多相关文章

  1. DP 做题记录 II.

    里面会有一些数据结构优化 DP 的题目(如 XI.),以及普通 DP. *I. P3643 [APIO2016]划艇 题意简述:给出序列 \(a_i,b_i\),求出有多少序列 \(c_i\) 满足 ...

  2. Sam做题记录

    Sam做题记录 Hihocoder 后缀自动机二·重复旋律5 求一个串中本质不同的子串数 显然,答案是 \(\sum len[i]-len[fa[i]]\) Hihocoder 后缀自动机三·重复旋律 ...

  3. 退役III次后做题记录(扯淡)

    退役III次后做题记录(扯淡) CF607E Cross Sum 计算几何屎题 直接二分一下,算出每条线的位置然后算 注意相对位置这个不能先搞出坐标,直接算角度就行了,不然会卡精度/px flag:计 ...

  4. BJOI做题记录

    BJOI做题记录 终于想起还要做一下历年省选题了2333 然而咕了的还是比做了的多2333 LOJ #2178. 「BJOI2017」机动训练 咕了. LOJ #2179. 「BJOI2017」树的难 ...

  5. DP刷题记录(持续更新)

    DP刷题记录 (本文例题目前大多数都选自算法竞赛进阶指南) TYVJ1071 求两个序列的最长公共上升子序列 设\(f_{i,j}\)表示a中的\(1-i\)与b中色\(1-j\)匹配时所能构成的以\ ...

  6. UOJ 做题记录

    UOJ 做题记录 其实我这么弱> >根本不会做题呢> > #21. [UR #1]缩进优化 其实想想还是一道非常丝播的题目呢> > 直接对于每个缩进长度统计一遍就好 ...

  7. project euler做题记录

    ProjectEuler_做题记录 简单记录一下. problem 441 The inverse summation of coprime couples 神仙题.考虑答案为: \[\begin{a ...

  8. 退役IV次后做题记录

    退役IV次后做题记录 我啥都不会了.... AGC023 D 如果所有的楼房都在\(S\)同一边可以直接得出答案. 否则考虑最左最右两边的票数,如果左边>=右边,那么最右边会投给左边,因为就算车 ...

  9. 退役II次后做题记录

    退役II次后做题记录 感觉没啥好更的,咕. atcoder1219 历史研究 回滚莫队. [六省联考2017]组合数问题 我是傻逼 按照组合意义等价于\(nk\)个物品,选的物品\(\mod k\) ...

  10. FJOI2017前做题记录

    FJOI2017前做题记录 2017-04-15 [ZJOI2017] 树状数组 问题转化后,变成区间随机将一个数异或一,询问两个位置的值相等的概率.(注意特判询问有一个区间的左端点为1的情况,因为题 ...

随机推荐

  1. Manage your references to .Net assemblies Dynamics 365 for Operations VS projects

    (Dynamics 365 for Operations was previously known as the New Dynamics AX) Dynamics 365 for Operation ...

  2. vs调试导入功能时莫名自动结束调试

    新装了vs2022,默认下图所示的地方打勾,导致调试文件导入功能时触发了自动结束调试,真是坑爹~~

  3. Java--接口和抽象类有什么区别

    他们都不能实例化对象,都可以包含抽象方法,而且抽象方法必须被继承的类全部实现. 区别: 1.抽象类和接口都不能直接实例化,如果要实例化,抽象类变量必须指向实现所有抽象方法的子类对象,接口变量必须指向实 ...

  4. <context:component-scan/>和<mvc:annotation-driven/>的区别

    1 <context:annotation-config/> 如果你想使用@Autowired注解,那么就必须事先在 spring 容器中声明 AutowiredAnnotationBea ...

  5. 虚拟环境 venv的使用--(venv 一)

    一.引言最近在学习<Flask Web Development 2nd Edition>的时候,作者开篇就介绍如何使用 venv 来管理 Python 环境 .自我觉得作者讲的非常好,想要 ...

  6. 说来惭愧,关于Session的某块知识的学习,感觉涨了知识

    Session的查漏补缺 今天在写界面的时候,想要利用servlet和jsp页面实现界面的跳转,之前实现这些内容的时候,我是没有用到session来实现这个功能的. 直到今天,想要将第一个界面的数据隔 ...

  7. Fiddler一些用法学习记录

    最近项目中用Fiddler较多,只会之前掌握的一些最简单的用法显得有点不太够.记录一下学习到的新用法. 一.需要mock.打开AutoResponder,Add Rule,填上需要mock的网址,需要 ...

  8. Python ArcPy批量拼接长时间序列栅格图像

      本文介绍基于Python中ArcPy模块,对大量不同时相的栅格遥感影像按照其成像时间依次执行批量拼接的方法.   在前期的文章Python arcpy创建栅格.批量拼接栅格中,我们介绍了利用Pyt ...

  9. 阿里巴巴为什么建议使用BigDecimal进行浮点数运算

    本文先引入一个例子,星期天你和女朋友去逛街,看到一家奶茶店.女朋友想喝奶茶了,你就去买了杯奶茶,然后你问了一下价格.店员说奶茶0.9元一杯.然后你给了1元钱.这个时候你忽然问了一下女友.服务员该找我们 ...

  10. LLaMA:开放和高效的基础语言模型

    LLaMA:开放和高效的基础语言模型 论文:https://arxiv.org/pdf/2302.13971.pdf 代码:https://github.com/facebookresearch/ll ...