09:配對鹼基鏈
- 總時間限制:
- 1000ms
- 內存限制:
- 65536kB
- 描述
-
脫氧核糖核酸(DNA)由兩條互補的鹼基鏈以雙螺旋的方式結合而成。而構成DNA的鹼基共有4種,分別爲腺瞟呤(A)、鳥嘌呤(G)、胸腺嘧啶(T)和胞嘧啶(C)。我們知道,在兩條互補鹼基鏈的對應位置上,腺瞟呤總是和胸腺嘧啶配對,鳥嘌呤總是和胞嘧啶配對。你的任務就是根據一條單鏈上的鹼基序列,給出對應的互補鏈上的鹼基序列。
- 輸入
- 第一行是一個正整數n,表明共有n條要求解的鹼基鏈。
以下共有n行,每行用一個字符串表示一條鹼基鏈。這個字符串只含有大寫字母A、T、G、C,分別表示腺瞟呤、胸腺嘧啶、鳥嘌呤和胞嘧啶。每條鹼基鏈的長度都不超過255。 - 輸出
- 共有n行,每行爲一個只含有大寫字母A、T、G、C的字符串。分別爲與輸入的各鹼基鏈互補的鹼基鏈。
- 樣例輸入
-
5 ATATGGATGGTGTTTGGCTCTG TCTCCGGTTGATT ATATCTTGCGCTCTTGATTCGCATATTCT GCGTTTCGTTGCAA TTAACGCACAACCTAGACTT
- 樣例輸出
-
TATACCTACCACAAACCGAGAC AGAGGCCAACTAA TATAGAACGCGAGAACTAAGCGTATAAGA CGCAAAGCAACGTT AATTGCGTGTTGGATCTGAA
- 查看
- 提交
- 統計
- 提問
-
-
#include<stdio.h> #include<string.h> #define N 256 int main() { int n; char arr[N]; char *p = arr; scanf("%d",&n); for(int i =0;i<n;i++) { scanf("%s",p); int len = strlen(arr); for(int j = 0;j<len;j++) { if(*(p+j) =='A') *(p+j) = 'T'; else if(*(p+j) =='T') *(p+j) = 'A'; else if(*(p+j) =='G') *(p+j) = 'C'; else if(*(p+j) =='C') *(p+j) = 'G'; } printf("%s\n",p); } return 0; }