187. 重复的DNA序列 --力扣 --JAVA

题目

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

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

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

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

解题思路

  1. 遍历将字符串每十个字符分割成一个字符串存储到Map中进行统计出现次数;
  2. 将出现次数超过1次的存储到list当中输出。

代码展示

java 复制代码
class Solution {
    public List<String> findRepeatedDnaSequences(String s) {
        Map<String,Integer> data = new HashMap<>();
        for (int i = 0; i <= s.length() - 10; i++){
            String str = s.substring(i, i + 10);
            Integer temp = data.getOrDefault(str, 0);
            data.put(str, temp + 1);
        }
        List<String> ans = new ArrayList<>();
        for (String str : data.keySet()){
            if(data.get(str) > 1){
                ans.add(str);
            }
        }
        return ans;
    }
}
相关推荐
User_芊芊君子2 分钟前
【LeetCode经典题解】递归破解对称二叉树之谜
算法·leetcode·职场和发展
Rock_yzh4 分钟前
LeetCode算法刷题——49. 字母异位词分组
数据结构·c++·学习·算法·leetcode·职场和发展·哈希算法
小欣加油4 分钟前
leetcode 2654 使数组所有元素变成1的最少操作次数
数据结构·c++·算法·leetcode·职场和发展
Kt&Rs7 分钟前
11.12 LeetCode 题目汇总与解题思路
算法·leetcode
m0_5656111321 分钟前
Java Stream流操作全解析
java·开发语言·算法
大千AI助手29 分钟前
决策树悲观错误剪枝(PEP)详解:原理、实现与应用
人工智能·算法·决策树·机器学习·剪枝·大千ai助手·悲观错误剪枝
九年义务漏网鲨鱼1 小时前
【机器学习算法】面试中的ROC和AUC
算法·机器学习·面试
草莓熊Lotso1 小时前
《算法闯关指南:优选算法--位运算》--38.消失的两个数字
服务器·c++·算法·1024程序员节
剪一朵云爱着6 小时前
力扣81. 搜索旋转排序数组 II
算法·leetcode·职场和发展
报错小能手9 小时前
刷题日常 5 二叉树最大深度
算法