欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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的时候录不进去序列内容?03:基因相关性
如图只能输入一行字符串
03:基因相关性
验证加数组c之后,输出a,b,c

知识点:gets()的输入范围是从光标处一直到回车,数组c的作用是录入了输入阙值后一直到回车的空白部分。第二行才真正开始是DNA序列。
心得:虽然只是个小小知识点,但是解决了问题真的蛮开心的