1131:基因相关性
时间限制: 1000 ms 内存限制: 65536 KB
提交数: 31551 通过数: 15925
【题目描述】
为了获知基因序列在功能和结构上的相似性,经常需要将几条不同序列的DNA进行比对,以判断该比对的DNA是否具有相关性。
现比对两条长度相同的DNA序列。定义两条DNA序列相同位置的碱基为一个碱基对,如果一个碱基对中的两个碱基相同的话,则称为相同碱基对。接着计算相同碱基对占总碱基对数量的比例,如果该比例大于等于给定阈值时则判定该两条DNA序列是相关的,否则不相关。
【输入】
有三行,第一行是用来判定出两条DNA序列是否相关的阈值,随后2行是两条DNA序列(长度不大于500)。
【输出】
若两条DNA序列相关,则输出“yes”,否则输出“no”。
【输入样例】
0.85 ATCGCCGTAAGTAACGGTTTTAAATAGGCC ATCGCCGGAAGTAACGGTCTTAAATAGGCC
【输出样例】
yes
【参考代码】
C代码:
#include <stdio.h> #include <string.h> #define N 510 char s1[N],s2[N]; int main() { int i,len; double x,sum=0; scanf("%lf",&x); getchar(); gets(s1); gets(s2); len=strlen(s1); for(i=0;i<len;i++) if(s1[i]==s2[i]) sum++; if(sum/len>=x) printf("yes\n"); else printf("no\n"); return 0; }
C++代码:
#include <iostream> #include <string> using namespace std; int main() { double x,sum=0; string s1,s2; cin >> x >> s1 >> s2; for(int i=0;i<s1.size();i++) if(s1[i]==s2[i]) sum++; if(sum/s1.size()>=x) cout << "yes" << endl; else cout << "no" << endl; return 0; }
http://ybt.ssoier.cn:8088/problem_show.php?pid=1131