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的情况,因为题 ...
随机推荐
- Integer类自动拆箱,装箱解析
1.自动拆箱 例1: int i1 = 10; Integer i2 = new Integer(10); System.out.println(i1 == i2); 这个结果是true i1为基本数 ...
- Mybatis二级缓存问题
一.缓存介绍. Mybatis提供了缓存服务,以减缓数据库压力: Mybatis的查询缓存总共有两级,我们称之为一级缓存和二级缓存,如图: 1.一级缓存是SqlSession级别的缓存.在操作数据 ...
- python-GUI-tkinter之excel密码破解工具
python gui 之熟悉tkinter部分控件使用.一个简单的excel暴力密码破解,核心很简单,基本就是一个函数外面加了GUI,写的很啰嗦,希望大家可以在优化改良下,主要是为了再熟悉下tkint ...
- Anaconda与conda、pip与conda的区别 - 搬运
Anaconda与conda.pip与conda的区别 风影忍着 转自:https://zhuanlan.zhihu.com/p/379321816 作为一个Python初学者,在请教资深 ...
- 有时候用uniapp写项目时发现,Map组件在安卓真机可以缩放和移动,但是在ios真机就不行
如果你的地图组件是放到popup组件里,是用弹框打开的,如何ios端不能缩放, 那你一定要看下这个弹框的层级是否比地图层级要高 z-index. 如果高于地图层级,那地图肯定是不能移动和缩放的
- 【已解决】appium启动会话时遇到的的几种问题
第一种: 1.启动会话时一直卡在加载界面,报错log信息及截图如下 [ADB] Creating ADB subprocess with args: ["-P",5037,&quo ...
- H5-生成二维码
<div class="poster-qr"> <div class="qrWrapper"> <!-- 放置二维码的容器 --& ...
- C++ (伪)随机数生成
#include <iostream> #include <random> namespace random { // 从系统获取随机数作为种子 std::random_dev ...
- 阿里巴巴为什么建议使用BigDecimal进行浮点数运算
本文先引入一个例子,星期天你和女朋友去逛街,看到一家奶茶店.女朋友想喝奶茶了,你就去买了杯奶茶,然后你问了一下价格.店员说奶茶0.9元一杯.然后你给了1元钱.这个时候你忽然问了一下女友.服务员该找我们 ...
- dart基础---->函数传值
1. string type main(List<String> args) { String name = "huhx"; changIt(name); print( ...