描述
脱氧核糖核酸(DNA)由两条互补的碱基链以双螺旋的方式结合而成。而构成DNA的碱基共有4种,分别为腺瞟呤(A)、鸟嘌呤(G)、胸腺嘧啶(T)和胞嘧啶(C)。我们知道,在两条互补碱基链的对应位置上,腺瞟呤总是和胸腺嘧啶配对,鸟嘌呤总是和胞嘧啶配对。你的任务就是根据一条单链上的碱基序列,给出对应的互补链上的碱基序列。
输入
一个字符串,表示一条碱基链。这个字符串只含有大写字母A、T、G、C,分别表示腺瞟呤、胸腺嘧啶、鸟嘌呤和胞嘧啶。字符串长度不超过255。
输出
一个只含有大写字母A、T、G、C的字符串,为与输入的碱基链互补的碱基链。
样例输入
ATATGGATGGTGTTTGGCTCTG
样例输出
TATACCTACCACAAACCGAGAC
源码
方法一
#include<stdio.h>
//#include<string.h>
#define max 256
int main() {
char str[max];
gets(str);
int len = strlen(str);
for (int i=0; i<len; i++){
if (str[i] == 'A') str[i] = 'T';
else if (str[i] == 'T') str[i] = 'A';
else if (str[i] == 'G') str[i] = 'C';
else str[i] = 'G';
}
printf("%s",str);
return 0;
}
方法二
#include<stdio.h>
//#include<string.h>
#define max 256
int main() {
char str[max];
gets(str);
int len = strlen(str);
for(int i=0; i<len; i++)
{
switch(str[i])
{
case'A':
printf("%c",'T'); break;
case'T':
printf("%c",'A'); break;
case'C':
printf("%c",'G');break;
case'G':
printf("%c",'C');break;
}
}
return 0;
}