博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode 433.最小基因变化
阅读量:5107 次
发布时间:2019-06-13

本文共 1956 字,大约阅读时间需要 6 分钟。

最小基因变化

一条基因序列由一个带有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
bankSet = new HashSet<>();12 for (String s : bank)13 bankSet.add(s);14 Queue
q = new LinkedList<>();15 HashMap
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 }

 

 

 

转载于:https://www.cnblogs.com/kexinxin/p/10242231.html

你可能感兴趣的文章
js获取服务器时间
查看>>
WimMaker 2.0 (2013.10) WIM制作工具
查看>>
C#字符串加密和解密
查看>>
关于加班
查看>>
MapWindowPoints
查看>>
C# 基本数据类型
查看>>
为什么越来越多公链项目将WASM拥入怀中?
查看>>
「NOI2018」屠龙勇士
查看>>
C#分割字符串
查看>>
eclipse svn
查看>>
数据库表添加行号
查看>>
linux下批量替换文件内容
查看>>
Replacing Accented characters(Diacritic) .NET
查看>>
ASP.NET session时间的设置
查看>>
120. Triangle
查看>>
九、python基础(多进程、进程队列Queues、Pipes管道、Managers、进程池、selery 分布式任务队列)...
查看>>
[文件系统]文件系统学习笔记(九)---rootfs
查看>>
CentOS优化
查看>>
Springboot 中配置文件的优先级和加载顺序
查看>>
Drawable资源
查看>>