187. 重复的DNA序列 187. 重复的 DNA 序列题目1234567891011121314151617181920所有 DNA 都由一系列缩写为 'A','C','G' 和 'T' 的核苷酸组成,例如:"ACGAATTCCG"。在研究 DNA 时,识别 DNA 中的重复序列有时会对研究非常有帮助。编写一个函数来找出所有目标子串,目标子串的长度为 10,且在 DNA 字符串 s 中出现次数超过一次。 示例 1:输入:s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT"输出:["AAAAACCCCC","CCCCCAAAAA"]示例 2:输入:s = "AAAAAAAAAAAAA"输出:["AAAAAAAAAA"] 提示:0 <= s.length <= 105s[i] 为 'A'、'C'、'G' 或 'T' 题目思路 1、滑动窗口,以 10 为值 1234567891011121314151617class Solution {public: vector<string> findRepeatedDnaSequences(string s) { vector<string> ans; int n = s.size(); unordered_map<string, int> st; for(int i = 0, j = 9; j < n; j++, i++) { if(st[s.substr(i,10)] == 1) { ans.push_back(s.substr(i, 10)); } st[s.substr(i, 10)]++; } return ans; }}; 复杂度 时间复杂度:O(n*C) 空间复杂度:O(n) Leetcode 187. 重复的DNA序列 https://chaggle.github.io/2021/10/08/Leetcode/187/ 作者 chaggle 发布于 2021年10月8日 许可协议 16. 最接近的三数之和 上一篇 Day 29 997. 找到小镇的法官 下一篇 Please enable JavaScript to view the comments