leetcode做题笔记127. 单词接龙

字典 wordList 中从单词 beginWordendWord转换序列 是一个按下述规格形成的序列 beginWord -> s1 -> s2 -> ... -> sk

  • 每一对相邻的单词只差一个字母。
  • 对于 1 <= i <= k 时,每个 si 都在 wordList 中。注意, beginWord不需要在 wordList 中。
  • sk == endWord

给你两个单词beginWordendWord 和一个字典 wordList ,返回 beginWordendWord最短转换序列 中的 单词数目 。如果不存在这样的转换序列,返回 0

思路一:BFS

cpp 复制代码
#define MAX_QUEUE_LEN 100000

int isSequ(char* a, char* b){
    int len = strlen(a);
    int count = 0;
    for(int i = 0; i < len; i++){
        if(a[i] != b[i])
            count++;
    }
    if(count == 1)
        return true;
    else
        return false;

}

int ladderLength(char *beginWord, char *endWord, char **wordList, int wordListSize)
{
    char* queueList[MAX_QUEUE_LEN] = {0};       //定义一个很大的数组,用来当做队列
    int head = 0;                               //需要首尾指针标记
    int tail = 0; 

    for(int i = 0; i < wordListSize; i++){
        if(strcmp(endWord, wordList[i]) == 0){  //字符串中有可以匹配的
            break;
        }
        if(i == wordListSize-1) return 0;       //字符串数组中没有匹配的,return 0
    }
    int* mark = (int*)malloc(wordListSize*sizeof(int)); //需要标识这个字符串是否已经遍历过了,避免死循环
    memset(mark, 0, wordListSize * sizeof(int));

    queueList[tail++] = beginWord;              //初始,起始字符串入队列,尾指针+1
    int step = 1;
    while(head != tail){                        //队列不为空,遍历未结束
        int scop = tail-head;                   //广度搜索,当前这一层有多少个
        for(int i = 0; i < scop; i++){      
            char *temp = queueList[head++]; 
            if(strcmp(temp, endWord) == 0){     //相当于出队列,判断是否符合。首指针++
                free(mark);         
                return step;
            }
            for(int j = 0; j < wordListSize; j++){  //相当于搜索下一层,查是否存在可以变化的  
                if(mark[j] == 0 && isSequ(temp, wordList[j])){
                    mark[j] = 1;
                    queueList[tail++] = wordList[j];
                }
            }
        }
        step++;
    }
    free(mark);
    return 0;
}

分析:

本题要将返回最短转换序列的数目,可以采用广度优先搜索和队列解决问题,将字符存入队列,不断判断队列中结尾字符是否符合,不断使用isSequ函数进行判断。最后返回最短转换序列数

总结:

本题考察广度优先搜索的引用,由于判断最后一位的过程和队列的特点比较符合,故采用队列记录字符串经判断后输出最短转换序列数。

相关推荐
じ☆冷颜〃15 小时前
实分析与测度论、复分析、傅里叶分析、泛函分析、凸分析概述.
笔记·学习·数学建模·拓扑学·傅立叶分析
刀法如飞15 小时前
Ontology本体论是什么数据结构?Palantir 技术原理介绍
数据结构·人工智能·ai编程·图论
kobesdu16 小时前
【ROS2实战笔记-19】ROS2 生命周期节点的启动顺序、状态转换陷阱与热备方案
java·前端·笔记·机器人·ros·ros2
平行侠16 小时前
024多精度大整数 - 突破硬件精度限制的任意精度运算
数据结构·算法
谙弆悕博士16 小时前
快速学C语言——第16章:预处理
c语言·开发语言·chrome·笔记·创业创新·预处理·业界资讯
洛水水17 小时前
【力扣100题】32.将有序数组转换为二叉搜索树
数据结构·算法·leetcode
handler0117 小时前
UDP协议与网络通信知识点
c语言·网络·c++·笔记·网络协议·udp
如竟没有火炬17 小时前
用队列实现栈
开发语言·数据结构·python·算法·leetcode·深度优先
RH23121118 小时前
2026.5.12 Linux
java·linux·数据结构
水木流年追梦18 小时前
大模型入门-应用篇3-Agent智能体
开发语言·python·算法·leetcode·正则表达式