算法:DNA 配对 (learn to code at freeCodeCamp)

题目

算法中级:DNA 配对

在这道题目中,我们需要写一个函数,为 DNA 中的碱基配对。这个函数只接收一个表示碱基的字符串为参数,最后返回完成配对的二维数组。

碱基对 由一对碱基组成。碱基有四种,分别为 A(腺嘌呤)、T(胸腺嘧啶)、G(鸟嘌呤)和 C(胞嘧啶)。配对原则是:A 与 T 配对,C 与 G 配对。我们需要根据这个原则对传入的所有碱基进行配对。

对于每个传入的碱基,我们应采用数组的形式展示配对结果。其中,传入的碱基需要作为数组的第一个元素出现。最终返回的数组中应当包含参数中每一个碱基的配对结果。

比如,传入的参数是 GCG,那么函数的返回值应为 [[“G”, “C”], [“C”,“G”],[“G”, “C”]]

pairElement(“ATCGA”)应该返回[[“A”,“T”],[“T”,“A”],[“C”,“G”],[“G”,“C”],[“A”,“T”]]。

pairElement(“TTGAG”)应该返回[[“T”,“A”],[“T”,“A”],[“G”,“C”],[“A”,“T”],[“G”,“C”]]。

pairElement(“CTCTA”)应该返回[[“C”,“G”],[“T”,“A”],[“C”,“G”],[“T”,“A”],[“A”,“T”]]。

解题

function pairElement(str) {
    
    
  let arr = [];
  function getStr(s) {
    
    
    let res = "";
    switch(s){
    
    
      case "G": res="C" ; break;
      case "C": res="G" ; break;
      case "T": res="A" ; break;
      case "A": res="T" ; break;
    }
    return res;
  }
  for(let i=0;i<str.length;i++){
    
    
    arr.push([str[i],getStr(str[i])])
  }
  return arr;
}

pairElement("GCG");

猜你喜欢

转载自blog.csdn.net/weixin_43245095/article/details/115112253