Leetcode 433.最小基因变化

最小基因变化

一条基因序列由一个带有8个字符的字符串表示,其中每个字符都属于 "A", "C", "G", "T"中的任意一个。

假设我们要调查一个基因序列的变化。一次基因变化意味着这个基因序列中的一个字符发生了变化。

例如,基因序列由"AACCGGTT" 变化至 "AACCGGTA" 即发生了一次基因变化。

与此同时,每一次基因变化的结果,都需要是一个合法的基因串,即该结果属于一个基因库。

现在给定3个参数 — start, end, bank,分别代表起始基因序列,目标基因序列及基因库,请找出能够使起始基因序列变化为目标基因序列所需的最少变化次数。如果无法实现目标变化,请返回 -1。

注意:

  1. 起始基因序列默认是合法的,但是它并不一定会出现在基因库中。
  2. 所有的目标基因序列必须是合法的。
  3. 假定起始基因序列与目标基因序列是不一样的。

示例 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

 

 

利用广度优先搜索查找最短路径

 

 1 import java.util.HashMap;
 2 import java.util.HashSet;
 3 import java.util.LinkedList;
 4 import java.util.Queue;
 5 
 6 
 7 class Solution {
 8     public int minMutation(String start, String end, String[] bank) {
 9         if (bank == null || bank.length == 0) return -1;
10         char[] gen = {'A','C','G','T'};
11         HashSet<String> bankSet = new HashSet<>();
12         for (String s : bank)
13             bankSet.add(s);
14         Queue<String> q = new LinkedList<>();
15         HashMap<String, Integer> res = new HashMap<>();
16         res.put(start, 0);
17         q.add(start);
18         while (!q.isEmpty()) {
19             String s = q.poll();
20             bankSet.remove(s);
21             for (int i = 0; i < s.length(); i++) {
22                 char[] next = s.toCharArray();
23                 for (char c : gen) {
24                     next[i] = c;
25                     String nextS = new String(next);
26                     if (bankSet.contains(nextS)) {
27                         res.put(nextS, res.get(s) + 1);
28                         if (nextS.equals(end)) return res.get(nextS);
29                         q.add(nextS);
30                     }
31                 }
32             }
33         }
34         return -1;
35     }
36 }

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值