首页 > 代码库 > 互补的碱基链

互补的碱基链

字符串
6

【描述】

脱氧核糖核酸(DNA)由两条互补的碱基链以双螺旋的方式结合而成。而构成DNA的碱基共有4种,分别为腺瞟呤(A)、鸟嘌呤(G)、胸腺嘧啶(T)和胞嘧啶(C)。在两条互补碱基链的对应位置上,腺瞟呤总是和胸腺嘧啶配对,鸟嘌呤总是和胞嘧啶配对。你的任务就是根据一条单链上的碱基序列,给出对应的互补链上的碱基序列。

【输入】

第一行是一个正整数n,表明共有n条要求解的碱基链。

以下共有n行,每行用一个字符串表示一条碱基链。这个字符串只含有大写字母ATGC,分别表示腺瞟呤、胸腺嘧啶、鸟嘌呤和胞嘧啶。每条碱基链的长度都不超过255

【输出】

共有n行,每行为一个只含有大写字母ATGC的字符串。分别为与输入的各碱基链互补的碱基链。

【输入示例】

5

ATATGGATGGTGTTTGGCTCTG

TCTCCGGTTGATT

ATATCTTGCGCTCTTGATTCGCATATTCT

GCGTTTCGTTGCAA

TTAACGCACAACCTAGACTT

【输出示例】

TATACCTACCACAAACCGAGAC

AGAGGCCAACTAA

TATAGAACGCGAGAACTAAGCGTATAAGA

CGCAAAGCAACGTT

AATTGCGTGTTGGATCTGAA





#include<stdio.h>
#include<string.h>

int main(){
	int i,n,l;
	char a[300];
	scanf("%d",&n);
	n++;//这里因为最后面的puts会带一个换行符,被最后一轮gets拿走了,导致最后一轮失效,所以要多一轮 
	while(n--){
		gets(a);
		l=strlen(a);
		for(i=0;i<l;i++){
			if(a[i]=='A')
				a[i]='T';
			else if(a[i]=='T')
				a[i]='A';
			else if(a[i]=='G')
				a[i]='C';
			else if(a[i]=='C')
				a[i]='G';
		}
			puts(a);

	}
} 


互补的碱基链