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
}
}