原文:187. 重复的DNA序列(leetcode 解题) - 每天一个JavaScript小知识@Js中文网 · 码农进阶题库

原文地址:https://www.javascriptc.com/interview-tips/zh_cn/leetcode/leetcode-javascript-solution-0187/

题目:

难度:Middle

相关话题:位运算哈希表

所有 DNA 由一系列缩写为 A,C,G 和 T 的核苷酸组成,例如:“ACGAATTCCG”。在研究 DNA 时,识别 DNA 中的重复序列有时会对研究非常有帮助。

编写一个函数来查找 DNA 分子中所有出现超多一次的10个字母长的序列(子串)。

示例:

输入: s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT"

输出: ["AAAAACCCCC", "CCCCCAAAAA"]

思路:

10个字符就存入hash,如果有重复,hash对应的val+1,最终只返回hashval为2的字符串,既重复出现了,也避免重复返回。

/**
 * @来源: Javascript中文网 - 前端进阶资源教程 https://www.javascriptc.com/
 * @介绍:一个致力于帮助开发者用代码改变世界为使命的平台,每天都可以在这里找到技术世界的头条内容
 * @param {string} s
 * @return {string[]}
 */
var findRepeatedDnaSequences = function(s) {
  let hash={}
  let res=[]
  for(let i=0;i<=s.length-10;i++){
    let str=s.substring(i,i+10)
    if(hash[str]==null){
      hash[str]=1
    }else{
      hash[str]++
    }
    if(hash[str]===2)res.push(str)
  }
  return res
};

扩展阅读: