算法--水题-DNA合成

    xiaoxiao2021-03-26  5

    [编程题] DNA合成 DNA分子是以4种脱氧核苷酸为单位连接而成的长链,这4种脱氧核苷酸分别含有A,T,C,G四种碱基。碱基互补配对原则:A和T是配对的,C和G是配对的。如果两条碱基链长度是相同的并且每个位置的碱基是配对的,那么他们就可以配对合成为DNA的双螺旋结构。现在给出两条碱基链,允许在其中一条上做替换操作:把序列上的某个位置的碱基更换为另外一种碱基。问最少需要多少次让两条碱基链配对成功
    输入描述:
    输入包括一行: 包括两个字符串,分别表示两条链,两个字符串长度相同且长度均小于等于50。
    输出描述:
    输出一个整数,即最少需要多少次让两条碱基链配对成功
    输入例子:
    ACGT TGCA
    输出例子:
    0
    #define maxn 150 char s[maxn]; void dnatest() { int count = 0; gets_s(s,maxn); size_t l = strlen(s); int len = l / 2; for (int i = 0; i < len; i++) { int j = len+1+ i; if ((s[i] == 'A'&&s[j] == 'T') || (s[i] == 'T'&&s[j] == 'A') || (s[i] == 'C'&&s[j] == 'G') || (s[i] == 'G'&&s[j] == 'C')) { } else { count++; } } printf_s("%d", count); } int main() { dnatest(); return 0; }
    转载请注明原文地址: https://ju.6miu.com/read-600187.html

    最新回复(0)