zoukankan      html  css  js  c++  java
  • 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 }

     

     

  • 相关阅读:
    卷积神经网络(3)
    卷积神经网络(2)
    五款最佳Linux下载管理器推荐
    SSH如何通过公钥连接云服务器
    揭露QPS增高后的秘密
    总结六条对我们学习Linux系统有用的忠告
    第一款支持容器和云部署的开源数据库Neo4j 3.0
    /etc/bashrc和/etc/profile傻傻分不清楚?
    手把手教你crontab排障
    awk系列:在awk中如何使用流程控制语句
  • 原文地址:https://www.cnblogs.com/kexinxin/p/10242231.html
Copyright © 2011-2022 走看看