day72(1.31)——leetcode面试经典150

433. 最小基因变化

433. 最小基因突变

这里我一开始弄错了,我直接一开始就将s标记好,但是我发现这样有的样例是过不了的,因为只有有效突变才能作为标记成已经访问

题目:

题解:

java 复制代码
class Solution {
    public int minMutation(String startGene, String endGene, String[] bank) {
        //先用映射将基因库中的序列赋值,方便寻找
        Map<String, Integer> map = new HashMap<>();
        for(int i=0;i<bank.length;i++) {
            map.put(bank[i], 1);
        } 
        Queue<String> queue = new LinkedList<>();
        queue.offer(startGene);
        int step = 0;
        while(queue.size()>0) {
            int size = queue.size();
            for(int l=0;l<size;l++) {
                String t = queue.poll();
                //判断一下跟最终需要的结果是否一样
                if(t.equals(endGene)) {
                    return step;
                }
                for(int i=0;i<bank.length;i++) {
                    String s = bank[i];
                    if(map.get(s)==0) {
                        continue;
                    }
                    
                    int diff = 0;
                    for(int j=0;j<s.length();j++) {
                        if(s.charAt(j)!=t.charAt(j)) {
                            diff++;
                        }
                    }
                    if(diff==1) {
                        queue.offer(s);
                        //只有有效突变才能将s标记为已访问
                        map.put(s, 0);
                    }
                }
            }
            //进行新增更改次数
            step++;  
        }
        return -1; 
    }
}
相关推荐
BUG?不,是彩蛋!2 分钟前
Token 相关的高频面试题
面试·职场和发展·token
Zhansiqi27 分钟前
day36花卉面试题目
面试·职场和发展
Moment41 分钟前
尤雨溪宣布 Vite+ 正式开源,前端工具链要大一统了
前端·javascript·面试
sunny_1 小时前
📖 2026年 大厂前端面试手写题库已开源(2.3k star)
前端·面试·github
眼眸流转2 小时前
LeetCode热题100(四)
算法·leetcode·职场和发展
深蓝轨迹3 小时前
乐观锁 vs 悲观锁 含面试模板
java·spring boot·笔记·后端·学习·mysql·面试
啊哦呃咦唔鱼3 小时前
LeetCode hot100-3 无重复字符的最长子串
算法·leetcode·职场和发展
愚者游世3 小时前
template学习大纲
开发语言·c++·程序人生·面试·visual studio
柒.梧.5 小时前
Java基础高频面试题(含详细解析+易错点,面试必看)
java·开发语言·面试
大大花猫5 小时前
求职简历的几个小建议
面试