[编程题]DNA合成

来源:互联网 发布:贵广网络股票千股千评 编辑:程序博客网 时间:2024/05/17 16:43
题目来源:牛客网   链接:https://www.nowcoder.com/questionTerminal/e95337f886f54110b92318f693cd8fad
DNA分子是以4种脱氧核苷酸为单位连接而成的长链,这4种脱氧核苷酸分别含有A,T,C,G四种碱基。碱基互补配对原则:A和T是配对的,C和G是配对的。如果两条碱基链长度是相同的并且每个位置的碱基是配对的,那么他们就可以配对合成为DNA的双螺旋结构。现在给出两条碱基链,允许在其中一条上做替换操作:把序列上的某个位置的碱基更换为另外一种碱基。问最少需要多少次让两条碱基链配对成功
输入描述:
输入包括一行: 包括两个字符串,分别表示两条链,两个字符串长度相同且长度均小于等于50
输出描述:
输出一个整数,即最少需要多少次让两条碱基链配对成功
示例1

输入

ACGT TGCA

输出

0
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ConsoleApp7
{
    class DNA合成
    {
        static void Main(string[] args)
        {
            Test test = new Test();
            string[] str = Console.ReadLine().Split(' ');
            test.test(str[0], str[1]);
        }
    }
    class Test
    {
        public void test(string str1, string str2)
        {
            int count = 0;
            Char[] char1 = str1.ToCharArray();
            Char[] char2 = str2.ToCharArray();
            for (int i = 0; i < char1.Length; i++)
            {
                switch (char1[i])
                {
                    case 'A': if (char2[i] != 'T') { count++; } break;
                    case 'T': if (char2[i] != 'A') { count++; } break;
                    case 'C': if (char2[i] != 'G') { count++; } break;
                    case 'G': if (char2[i] != 'C') { count++; } break;
                }
            }
            Console.WriteLine(count);
        }
    }
}
比较简单的题目,将字符串转化为数组,然后遍历数组分析,无法配对则+1。

原创粉丝点击