Leetcode 433.最小基因变化
最小基因变化
一条基因序列由一个带有8个字符的字符串表示,其中每个字符都属于 "A", "C", "G", "T"中的任意一个。
假设我们要调查一个基因序列的变化。一次基因变化意味着这个基因序列中的一个字符发生了变化。
例如,基因序列由"AACCGGTT" 变化至 "AACCGGTA" 即发生了一次基因变化。
与此同时,每一次基因变化的结果,都需要是一个合法的基因串,即该结果属于一个基因库。
现在给定3个参数 — start, end, bank,分别代表起始基因序列,目标基因序列及基因库,请找出能够使起始基因序列变化为目标基因序列所需的最少变化次数。如果无法实现目标变化,请返回 -1。
注意:
- 起始基因序列默认是合法的,但是它并不一定会出现在基因库中。
- 所有的目标基因序列必须是合法的。
- 假定起始基因序列与目标基因序列是不一样的。
示例 1:
start: "AACCGGTT"
end: "AACCGGTA"
bank: ["AACCGGTA"]
返回值: 1
示例 2:
start: "AACCGGTT"
end: "AAACGGTA"
bank: ["AACCGGTA", "AACCGCTA", "AAACGGTA"]
返回值: 2
示例 3:
start: "AAAAACCC"
end: "AACCCCCC"
bank: ["AAAACCCC", "AAACCCCC", "AACCCCCC"]
返回值: 3
利用广度优先搜索查找最短路径
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.Queue; class Solution {
public int minMutation(String start, String end, String[] bank) {
if (bank == null || bank.length == 0) return -1;
char[] gen = {'A','C','G','T'};
HashSet<String> bankSet = new HashSet<>();
for (String s : bank)
bankSet.add(s);
Queue<String> q = new LinkedList<>();
HashMap<String, Integer> res = new HashMap<>();
res.put(start, 0);
q.add(start);
while (!q.isEmpty()) {
String s = q.poll();
bankSet.remove(s);
for (int i = 0; i < s.length(); i++) {
char[] next = s.toCharArray();
for (char c : gen) {
next[i] = c;
String nextS = new String(next);
if (bankSet.contains(nextS)) {
res.put(nextS, res.get(s) + 1);
if (nextS.equals(end)) return res.get(nextS);
q.add(nextS);
}
}
}
}
return -1;
}
}
Leetcode 433.最小基因变化的更多相关文章
- Java实现 LeetCode 433 最小基因变化
		433. 一条基因序列由一个带有8个字符的字符串表示,其中每个字符都属于 "A", "C", "G", "T"中的任意一 ... 
- [Swift]LeetCode433. 最小基因变化 | Minimum Genetic Mutation
		A gene string can be represented by an 8-character long string, with choices from "A", &qu ... 
- [LeetCode] Minimum Genetic Mutation 最小基因变化
		A gene string can be represented by an 8-character long string, with choices from "A", &qu ... 
- leetcode 64. 最小路径和 动态规划系列
		目录 1. leetcode 64. 最小路径和 1.1. 暴力 1.2. 二维动态规划 2. 完整代码及执行结果 2.1. 执行结果 1. leetcode 64. 最小路径和 给定一个包含非负整数 ... 
- LeetCode#453 最小移动次数使数组元素相等
		给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移动次数.每次移动可以使 n - 1 个元素增加 1. 示例: 输入: [,,] 输出: 解释: 只需要3次移动(注意每次移动会增加两个 ... 
- LeetCode 453. 最小移动次数使数组元素相等(Minimum Moves to Equal Array Elements) 47
		453. 最小移动次数使数组元素相等 453. Minimum Moves to Equal Array Elements 题目描述 给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移 ... 
- LeetCode 64. 最小路径和(Minimum Path Sum) 20
		64. 最小路径和 64. Minimum Path Sum 题目描述 给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. 说明: 每次只能向下或 ... 
- leetcode.310最小高度树
		对于一个具有树特征的无向图,我们可选择任何一个节点作为根.图因此可以成为树,在所有可能的树中,具有最小高度的树被称为最小高度树.给出这样的一个图,写出一个函数找到所有的最小高度树并返回他们的根节点. ... 
- LeetCode 64最小路径和
		题目 给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. 说明:每次只能向下或者向右移动一步. 示例: 输入: [ [1,3,1], [1,5 ... 
随机推荐
- pm2-web监控
			pm2-web 是一款 pm2 服务状态监控程序,基于 web . 安装 npm install -g pm2-web 运行(默认占用8080端口) pm2-web 自定义配置文件 通过 --conf ... 
- 51nod 1525 重组公司
			题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 有n个人在公司里面工作.员工从1到n编号.每一个人属于一个部门.刚开始每一个人在自 ... 
- 突然心血来潮,想写写我在java面试中遇到的事。作为一个应届生,我觉得我的情况都与大部分应届生是差不多的,希望你们能在这上面得到一些有用的
			面试过程吧,怎么说呢?从一开始接触面试到现在成功了几家,这中间我确实收获了许多,那我就从我第一次面试开始讲吧. 第一次面试是有人介绍过来的,总之还是有一位贵人相助,所以第一次面试时,面试官很好没有怎么 ... 
- HDU 5452 Minimum Cut (Spaning Tree)
			生成树的上的一个非根结点对应一条生成树上的边,然后这个结点的子树上连出去的边就对应去掉这条边的割, 然后就可以对树外的边求LCA,在LCA上标记,利用这个信息可以算出有多少条边在子树上,以及有多少条边 ... 
- 如何从Ubuntu 16.04 LTS升级到Ubuntu 18.04 LTS
			可以说非常简单(假设过程顺利!!) 您只需打开Software&Update,进入"Updates"选项卡,然后从“有新版本时通知我”下拉菜单中选择“适用长期支持版”选项. ... 
- java HashMap 内存泄漏
			import java.util.HashMap; import java.util.Map; public class HashMapOver { public static void main(S ... 
- 如何下载js类库
			https://bower.io/ 这个已经淘汰 https://learn.jquery.com/jquery-ui/environments/bower/ Web sites are made ... 
- 使用vs2013打开VS2015的工程文件的解决方案(适用于大多数vs低版本打开高版本)
			前言:重装系统前我使用的是vs2015(有点装*),由于使用2015实在在班上太另类了, 导致我想在其他同学的vs下看一看我写的代码都无法达成! 而且最关键的是交作业的时候,老师的2013也没有办法打 ... 
- JavaScript Dom编程艺术(1)
			Dom是一种可以供多种环境和多种程序设计语言使用的API: 一份文档就是一个节点树: 节电分为不同的类型:元素节点,属性节点,文档节点,元素节点分为属性节点和文档节点: getelementbyid( ... 
- 洛谷 P2568 GCD
			https://www.luogu.org/problemnew/show/P2568#sub 最喜欢题面简洁的题目了. 本题为求两个数的gcd是素数,那么我们将x和y拆一下, 假设p为$gcd(x, ... 
