力扣 187. 重复的DNA序列

1.题目

DNA序列 由一系列核苷酸组成,缩写为 'A', 'C', 'G' 和 'T'.。

例如,"ACGAATTCCG" 是一个 DNA序列 。

在研究 DNA 时,识别 DNA 中的重复序列非常有用。

给定一个表示 DNA序列 的字符串 s ,返回所有在 DNA 分子中出现不止一次的 长度为 10 的序列(子字符串)。你可以按 任意顺序 返回答案。
示例 1:

输入:s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT"

输出:["AAAAACCCCC","CCCCCAAAAA"]
示例 2:

输入:s = "AAAAAAAAAAAAA"

输出:["AAAAAAAAAA"]
提示:

0 <= s.length <= 10^5

s[i]=='A'、'C'、'G' or 'T'
来源:力扣(LeetCode)

2.思路及代码

返回所有在 DNA 分子中出现不止一次的 长度为 10 的序列,即统计不同子字符串的出现的次数,并将出现次数大于1的储存起来。至于如何统计就要用到STL中的map或unordered_map,简单来讲,两者储存的元素都是键(第一个元素)值(第二个元素)对,比如:map<int, int>就类似于vector<int>,而map<string, int>就可以通过string来查询int。至于两者的区别,map的内部是一个红黑树,会根据键的大小自动排序,unordered_map的内部则是哈希表,查找效率更高但更占内存。(具体可看大佬)显然这题用unordered_map更好,但map也不会超时。代码如下:

cpp 复制代码
class Solution {
public:
    vector<string> findRepeatedDnaSequences(string s) {
        //当s的长度小于等于10直接返回空数组
        if (s.size() <= 10) return {};
        vector<string>arr;
        unordered_map<string, int>mp;
        string::iterator it = s.begin();
        //遍历字符串,统计所有长度为10的字符串
        for (; it <= s.end() - 10; ++it) {
            string tmp(it, it + 10);
            ++mp[tmp];
        }
        unordered_map<string, int>::iterator it_map = mp.begin();
        //将出现次数超过1的字符串加入数组
        for (; it_map != mp.end(); ++it_map) {
            if (it_map->second > 1) {
                arr.push_back(it_map->first);
            }
        }
        return arr;
    }
};

map的运行结果:

unordered_map的运行结果:

相关推荐
ada7_4 分钟前
LeetCode(python)——73.矩阵置零
python·算法·leetcode·矩阵
小龙报16 分钟前
《算法通关指南C++编程篇 --- 初阶函数递归专题》
c语言·开发语言·c++·算法·创业创新·学习方法·visual studio
2501_9412366236 分钟前
分布式日志系统实现
开发语言·c++·算法
2501_9412355138 分钟前
C++与机器学习框架
开发语言·c++·算法
CoovallyAIHub40 分钟前
基于SimCLR的自监督 YOLO:YOLOv5/8也能在低标注场景目标检测性能飙升
深度学习·算法·计算机视觉
2501_941111861 小时前
C++模块化设计原则
开发语言·c++·算法
2501_941237531 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
_OP_CHEN1 小时前
算法基础篇:(十)贪心算法拓展之哈夫曼编码:从 “合并最优” 到数据压缩的传奇
c++·算法·贪心算法·蓝桥杯·哈夫曼编码·算法竞赛·acm/icpc
枫叶丹41 小时前
【Qt开发】Qt窗口(二) -> QToolBar工具栏
开发语言·数据库·c++·qt
l1t1 小时前
利用DuckDB列表一句SQL输出乘法口诀表
数据库·sql·算法·duckdb