freeCodeCamp/curriculum/challenges/chinese-traditional/02-javascript-algorithms-an.../intermediate-algorithm-scri.../dna-pairing.md

1.7 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
afd15382cdfb22c9efe8b7de DNA 配對 5 16009 dna-pairing

--description--

給出的 DNA 鏈上缺少配對元素。 請基於每個字符,獲取與其配對的元素,並將結果作爲二維數組返回。

DNA 的鹼基對 有兩種形式:一種是 A 與 T一種是 C 與 G。 請爲參數中給出的每個字符配對相應的鹼基。

注意,參數中給出的字符應作爲每個子數組中的第一個元素返回。

例如,傳入 GCG 時,應返回 [["G", "C"], ["C","G"], ["G", "C"]]

字符和它的配對組成一個數組中,所有配對數組放在一個數組裏。

--hints--

pairElement("ATCGA") 應返回 [["A","T"],["T","A"],["C","G"],["G","C"],["A","T"]]

assert.deepEqual(pairElement('ATCGA'), [
  ['A', 'T'],
  ['T', 'A'],
  ['C', 'G'],
  ['G', 'C'],
  ['A', 'T']
]);

pairElement("TTGAG") 應返回 [["T","A"],["T","A"],["G","C"],["A","T"],["G","C"]]

assert.deepEqual(pairElement('TTGAG'), [
  ['T', 'A'],
  ['T', 'A'],
  ['G', 'C'],
  ['A', 'T'],
  ['G', 'C']
]);

pairElement("CTCTA") 應返回 [["C","G"],["T","A"],["C","G"],["T","A"],["A","T"]]

assert.deepEqual(pairElement('CTCTA'), [
  ['C', 'G'],
  ['T', 'A'],
  ['C', 'G'],
  ['T', 'A'],
  ['A', 'T']
]);

--seed--

--seed-contents--

function pairElement(str) {
  return str;
}

pairElement("GCG");

--solutions--

var lookup = Object.create(null);
lookup.A = 'T';
lookup.T = 'A';
lookup.C = 'G';
lookup.G = 'C';

function pairElement(str) {
 return str.split('').map(function(p) {return [p, lookup[p]];});
}