第十一章:图论part04 110.字符串接龙 105.有向图的完全可达性 106.岛屿的周长(补)

任务日期:7.29

题目一链接: 110. 字符串接龙 (kamacoder.com)

思路:将本题寻找附近的字符串等效于寻找四周的陆地,即寻找周围与当前字符只有一位不同的字符串,然后加入到队列中并标记上,在此基础上要将字符串对应路径长度,最后输出长度即可

代码:

cpp 复制代码
#include <bits/stdc++.h>
//思路:将本题寻找附近的字符串等效于寻找四周的陆地,在此基础上要将字符串对应路径长度,最后输出长度即可
using namespace std;
int main() {
    int n;
    cin>>n;
    string beginstr,endstr;
    cin>>beginstr>>endstr;
    //定义一个字典集合,方便直接查找
    unordered_set<string> strlist;
    for(int i = 0;i < n;i ++) {
        string str;
        cin>>str;
        strlist.insert(str);
    }
    //定义一个地图,记录以string为结尾的路径长度,以便查找到endstr后直接返回长度
    //哈希表的插入和定义要注意
    unordered_map<string,int> visitedstr;
    //初始化visitedstr:插入beginstr,并且设置路径长度为1
    visitedstr.insert(pair<string,int> (beginstr,1));
    //进行bfs
    std::queue<string> que;
    que.push(beginstr);
    while(!que.empty()) {
        string cur = que.front();
        que.pop();
        int path = visitedstr[cur];//需要一个变量提前记录一下当前字符串的路径长度
        for(int i = 0;i < cur.size();i ++){//依次换cur字符串的各个位置
        string neword = cur;//如果换当前位置那么需要保证其他位置不动,所以要重新定义一个neword
        for(int j = 0;j < 26;j ++) {//每个位置依次便利26个字母
            neword[i] = j + 'a';
            if(neword == endstr) {
                cout<<path + 1;//第26行的作用在此体现
                return 0;
            }
            //确定递归终止条件
            if(strlist.count(neword) && !visitedstr.count(neword)) {//strlist里面有当前字符串并且当前字符串没有被标记
                que.push(neword);//第28行作用在此体现
                visitedstr.insert(pair<string,int> (neword,path + 1));第26行的作用在此体现:标记当前字符串并且当前路径+1
                }
            }
        }
    }
    cout<<0;
    return 0;
}

难点:1.哈希表集合和map的创建。集合:unordered_set<string> strlist; map:unordered_map<string,int> visitedstr;

2.哈希表的插入操作:visitedstr.insert(pair<string,int> (beginstr,1));

3.哈希表map的含义:以string为结尾的路径长度int.

4.用bfs求最短路径,原因在于它是一圈一圈的遍历,当到达目标点时当前路径长一定是最短路径。

,5.在每次便利一个新的string时要用path记录当前路径长度,




题目二链接:

思路:

代码:

难点:

解释细节1:




题目三链接:

思路:

代码:

难点:

解释细节1:

相关推荐
关于不上作者榜就原神启动那件事15 分钟前
模拟算法乒乓球
开发语言·c++·算法
Bug退退退12323 分钟前
ArrayList 与 LinkedList 的区别
java·数据结构·算法
88号技师44 分钟前
2025年7月一区SCI优化算法-Logistic-Gauss Circle optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
一个不知名程序员www2 小时前
算法学习入门---二分查找(C++)
c++·算法
2301_807997382 小时前
代码随想录-day26
数据结构·c++·算法·leetcode
闭着眼睛学算法2 小时前
【双机位A卷】华为OD笔试之【排序】双机位A-银行插队【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
TL滕2 小时前
从0开始学算法——第一天(认识算法)
数据结构·笔记·学习·算法
小欣加油2 小时前
leetcode 3318 计算子数组的x-sum I
c++·算法·leetcode·职场和发展
love is sour3 小时前
聚类(Clustering)详解:让机器自己发现数据结构
算法·支持向量机·聚类
烟袅3 小时前
LeetCode 142:环形链表 II —— 快慢指针定位环的起点(JavaScript)
前端·javascript·算法