题目:
DNA序列 由一系列核苷酸组成,缩写为
'A','C','G'和'T'.。
- 例如,
"ACGAATTCCG"是一个 DNA序列 。在研究 DNA 时,识别 DNA 中的重复序列非常有用。
给定一个表示 DNA序列 的字符串
s,返回所有在 DNA 分子中出现不止一次的 长度为10的序列(子字符串)。你可以按 任意顺序 返回答案。来源:力扣(LeetCode)
链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
示例:
示例 1:
输入:s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT"
输出:["AAAAACCCCC","CCCCCAAAAA"]
示例 2:
输入:s = "AAAAAAAAAAAAA"
输出:["AAAAAAAAAA"]
解法:
使用滑动窗口记录每个子串出现的次数。
代码:
pythonclass Solution: def findRepeatedDnaSequences(self, s: str) -> List[str]: dic = defaultdict(int) result = [] if len(s) >= 10: for index in range(len(s) - 9): dic[s[index: index + 10]] += 1 result = [k for k, v in dic.items() if v > 1] return result
力扣:187. 重复的DNA序列(Python3)
恽劼恒2023-11-30 20:42
相关推荐
Zero-Talent20 分钟前
位运算算法不穿格子的程序员23 分钟前
从零开始刷算法——双指针-三数之和&接雨水q***235735 分钟前
python的sql解析库-sqlparse18你磊哥1 小时前
Django WEB 简单项目创建与结构讲解无限进步_1 小时前
C语言数组元素删除算法详解:从基础实现到性能优化月殇_木言1 小时前
Python期末复习松涛和鸣1 小时前
16、C 语言高级指针与结构体Booksort1 小时前
【LeetCode】算法技巧专题(持续更新)OJAC1111 小时前
2026高校毕业生1270万!但这些学生却被名企用高薪“提前预定”!Controller-Inversion1 小时前
岛屿问题(dfs典型问题求解)