LeetCode之图的广度优先搜索

433. 最小基因变化

java 复制代码
class Solution {
    public int minMutation(String start, String end, String[] bank) {
        // 将基因库存储在集合中,便于快速查找
        Set<String> bankSet = new HashSet<>(Arrays.asList(bank));
        
        // 如果目标基因不在基因库中,则直接返回 -1
        if (!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
    }
}
相关推荐
小y要自律1 分钟前
11 string容器 - 子串获取
c++·算法·stl
t198751281 分钟前
三相计量芯片RN8302B驱动校正程序设计与实现
算法
期末考复习中,蓝桥杯都没时间学了6 分钟前
力扣刷题9
算法·leetcode·职场和发展
砚边数影10 分钟前
线性回归原理(二):梯度下降算法,Java实现单变量/多变量拟合
java·数据库·算法·线性回归·kingbase·kingbasees·金仓数据库
春日见17 分钟前
Docker如何基于脚本拉取镜像,配置环境,尝试编译
运维·驱动开发·算法·docker·容器
csdn_aspnet29 分钟前
Java常用算法深度解析:从集合框架到并发编程
java·算法
零基础的修炼32 分钟前
位运算---LC268丢失的数字
算法·leetcode·职场和发展
2301_7886624044 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
嫂子开门我是_我哥44 分钟前
第十七节:项目实战1:猜数字游戏(模块化开发实现)
开发语言·python·算法·游戏
啊阿狸不会拉杆1 小时前
《计算机操作系统》第十二章 - 保护和安全
开发语言·网络·c++·算法·安全·计算机组成原理·计算机操作系统