03:基因相关性
程序员文章站
2022-03-06 08:20:26
...
原题链接
总时间限制:1000ms
内存限制: 65536kB
描述:
为了获知基因序列在功能和结构上的相似性,经常需要将几条不同序列的DNA进行比对,以判断该比对的DNA是否具有相关性。 现比对两条长度相同的DNA序列。首先定义两条DNA序列相同位置的碱基为一个碱基对,如果一个碱基对中的两个碱基相同的话,则称为相同碱基对。接着计算相同碱基对占总碱基对数量的比例,如果该比例大于等于给定阈值时则判定该两条DNA序列是相关的,否则不相关。
输入
有三行,第一行是用来判定出两条DNA序列是否相关的阈值,随后2行是两条DNA序列(长度不大于500)。
输出
若两条DNA序列相关,则输出“yes”,否则输出“no”。
样例输入
0.85
ATCGCCGTAAGTAACGGTTTTAAATAGGCC
ATCGCCGGAAGTAACGGTCTTAAATAGGCC
样例输出
yes
#include <iostream>
#include<cstring>
#include <cstdio>
using namespace std;
int main(){
char a[600],b[600],c[10000];
float k,n=0.00;
cin>>k;
gets(c);//加入数组c的原因是为了让输入格式符合题目要求
gets(a);
gets(b);
int m;
m=strlen(a);
for(int i=0;i<m;i++)
if(a[i]==b[i])n=n+1;
n=n/m;
if(n>=k)cout<<"yes";
else cout<<"no";
return 0;
}
疑问:为什么没有c的时候录不进去序列内容?
如图只能输入一行字符串
验证加数组c之后,输出a,b,c
知识点:gets()的输入范围是从光标处一直到回车,数组c的作用是录入了输入阙值后一直到回车的空白部分。第二行才真正开始是DNA序列。
心得:虽然只是个小小知识点,但是解决了问题真的蛮开心的
上一篇: JAVA练习9—IO流
下一篇: 学习数据库之查询综合练习