题目:
难度:Middle
相关话题:位运算
、哈希表
所有 DNA 由一系列缩写为 A,C,G 和 T 的核苷酸组成,例如:“ACGAATTCCG”。在研究 DNA 时,识别 DNA 中的重复序列有时会对研究非常有帮助。
编写一个函数来查找 DNA 分子中所有出现超多一次的10个字母长的序列(子串)。
示例:
输入: s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT"
输出: ["AAAAACCCCC", "CCCCCAAAAA"]
思路:
每10
个字符就存入hash
,如果有重复,hash
对应的val
就+1
,最终只返回hash
中val
为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
};
扩展阅读: