优选算法_最小基因变化_bfs_C++

一.题目解析

算法讲解:

1.改变一个字符之后,需要在bank里面看一下存不存在,所以我们可以将bank数组导入到一个hash表里面快速判断存不存在.

2.遍历全部情况:一个指针遍历start的8个字母,再创建一个string change="AGCT"指针遍历一个位置四种情况.

3.枚举出来的字符串只有bank里面的才需要加入队列

4.使用hash表来表示该字符串已经遍历

5.BFS基础:队列 queue<string>q实现宽搜

判断该位置是否遍历(这里使用hash表

6.结合代码和抽象图再一次理解

二.代码编写:

以下代码有一个BUG

cpp 复制代码
class Solution {
public:
    int minMutation(string startGene, string endGene, vector<string>& bank) {
        unordered_set<string>vis;//判断是否遍历
        unordered_set<string>hash(bank.begin(),bank.end());//bankhash快速判断是否存在
        string change="AGCT";

        if(startGene==endGene)return 0;//边界情况
        if(!hash.count(endGene))return -1;

        queue<string>q;//队列实现宽搜
        q.push(startGene);
        vis.insert(startGene);
        int ret=0;
        while(q.size())
        {
            ret++;
            int sz=q.size();
            while(sz--)
            {
                string s=q.front();
                q.pop();
                for(int i=0;i<8;i++)//一字符串的8个位置
                {
                    for(int j=0;j<4;j++)
                    {
                        s[i]=change[j];//已经将原来的字符串改坏了,所以我们使用tmp修改
                        if(hash.count(s)&&!vis.count(s))
                        {
                            if(s==endGene)return ret;
                            else q.push(s),vis.insert(s);
                        }
                    }
                }

            }
        }
        return -1;
    }
};

正确代码编写:

cpp 复制代码
class Solution {
public:
    int minMutation(string startGene, string endGene, vector<string>& bank) {
        unordered_set<string>vis;//判断是否遍历
        unordered_set<string>hash(bank.begin(),bank.end());//bankhash快速判断是否存在
        string change="AGCT";

        if(startGene==endGene)return 0;//边界情况
        if(!hash.count(endGene))return -1;

        queue<string>q;//队列实现宽搜
        q.push(startGene);
        vis.insert(startGene);//哈希表标记已经搜索过的状态
        int ret=0;
        while(q.size())//BFS
        {
            ret++;
            int sz=q.size();
            while(sz--)
            {
                string s=q.front();
                q.pop();
                for(int i=0;i<8;i++)//一字符串的8个位置
                {
                    string tmp=s;//防止原字符串被污染
                    for(int j=0;j<4;j++)
                    {
                        tmp[i]=change[j];//已经将原来的字符串改坏了,所以我们使用tmp修改
                        if(hash.count(tmp)&&!vis.count(tmp))//在bank里面存在,并且没有遍历过
                        {
                            if(tmp==endGene)return ret;//相等就返回步数
                            else q.push(tmp),vis.insert(tmp);//BFS不相等就继续入队改变
                        }
                    }
                }

            }
        }
        return -1;
    }
};
相关推荐
贫民窟的勇敢爷们21 小时前
SpringBoot整合AOP切面编程实战,实现日志统一记录+接口权限校验
java·spring boot·spring
jerryinwuhan21 小时前
基于各城市站点流量的复合功能比较
开发语言·php
浅念-21 小时前
递归解题指南:LeetCode经典题全解析
数据结构·算法·leetcode·职场和发展·排序算法·深度优先·递归
Kiling_070421 小时前
Java集合进阶:Set与Collections详解
算法·哈希算法
AC赳赳老秦1 天前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
迈巴赫车主1 天前
Java基础:list、set、map一遍过
java·开发语言
智者知已应修善业1 天前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
灵犀学长1 天前
基于 Spring ThreadPoolTaskScheduler + CronTrigger 实现的动态定时任务调度系统
java·数据库·spring
洛水水1 天前
【力扣100题】33.验证二叉搜索树
算法·leetcode·职场和发展
SimpleLearingAI1 天前
聚类算法详解
算法·数据挖掘·聚类