433. 最小基因变化
class Solution {public int minMutation(String start, String end, String[] bank) {// 将基因库存储在集合中,便于快速查找Set<String> bankSet = new HashSet<>(Arrays.asList(bank));// 如果目标基因不在基因库中,则直接返回 -1if (!bankSet.contains(end)) {return -1;}// 定义 BFS 队列Queue<String> queue = new LinkedList<>();queue.offer(start);// 记录变换的步骤int steps = 0;// 定义基因的四个可变字符char[] genes = {'A', 'C', 'G', 'T'};// 开始 BFS 遍历while (!queue.isEmpty()) {int size = queue.size();// 处理当前层的所有基因变化for (int i = 0; i < size; i++) {String currentGene = queue.poll();// 如果当前基因是目标基因,返回步骤数if (currentGene.equals(end)) {return steps;}// 生成可能的下一步基因for (int j = 0; j < currentGene.length(); j++) {for (char gene : genes) {if (gene != currentGene.charAt(j)) { // 只替换与当前基因不同的字符StringBuilder nextGene = new StringBuilder(currentGene);nextGene.setCharAt(j, gene); // 替换字符String newGene = nextGene.toString();// 如果新生成的基因在库中,加入队列并从银行中移除以避免重复if (bankSet.contains(newGene)) {queue.offer(newGene);bankSet.remove(newGene); // 以避免将来再访问}}}}}steps++; // 每层遍历结束,步数加 1}return -1; // 如果无法到达目标基因,返回 -1}
}