Crack LeetCode 之 127. Word Ladder

2024-03-19 02:32
文章标签 leetcode word crack 127 ladder

本文主要是介绍Crack LeetCode 之 127. Word Ladder,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

https://leetcode.com/problems/word-ladder/

本文的解釋部分來自於鏈接,出於學習目的我租了部分整理和修改:https://blog.csdn.net/linhuanmars/article/details/23029973

本題的本質是图,圖的顶点则是每个字符串。因為每次只能改一個字符,所以該字符串的每个字符可能对应的边有25个(26个小写字母减去自己),那么一个字符串可能存在的边是25*L条。接下来我們再检查这些边对应的字符串是否在字典里,以此類推就可以得到一个完整的图的结构。根据题目的要求,等价于求这个图一个顶点到另一个顶点的最短路径,我们用广度优先搜索即可。
該算法中最差情况是把所有长度为L的字符串都掃描一遍,或者把字典中的字符串都掃描一遍,而长度为L的字符串共有26^L,所以时间复杂度是O(min(26^L, size(dict)),空间上需要存储访问情况,也是O(min(26^L, size(dict))。C++代码如下:

class Solution
{
public:int ladderLength(string start, string end, vector<string>& wordList){if(start.empty() || end.empty() || start.length()!=end.length())return 0;list<string> strlist;set<string> visited;set<string> dic;int level= 1;int lastNum = 1;int curNum = 0;strlist.push_back(start);visited.insert(start);for (vector<string>::iterator ite = wordList.begin(); ite!=wordList.end(); ++ite)dic.insert(*ite);while(strlist.empty() == false) {string cur = strlist.front();strlist.pop_front();lastNum--;for(int i=0;i<cur.length();i++) {string charCur = cur;for(char c='a';c<='z';c++) {charCur[i] = c;if( dic.find(charCur)!=dic.end() && visited.find(charCur)==visited.end()) {if(charCur == end)return level+1;curNum++;strlist.push_back(charCur);visited.insert(charCur);}}}if(lastNum==0) {lastNum = curNum;curNum = 0;level++;}}return 0;}
};

Python代码如下:

class Solution:def ladderLength(self, beginWord, endWord, wordList):if not beginWord or not endWord or not wordList:return 0;wordSet = set()for word in wordList:wordSet.add(word)level = 1processedSet = set()curList = [beginWord]while True:level = level + 1nextList = []for curWord in curList:if curWord in processedSet:continuefor i in range(len(curWord)):part1 = curWord[:i]; part2 = curWord[i+1:]for j in 'abcdefghijklmnopqrstuvwxyz':nextword = part1 + j + part2if nextword == curWord:continueif nextword not in wordSet:continueif nextword == endWord:return levelnextList.append(nextword)processedSet.add(curWord)if not nextList:return 0curList = nextListreturn 0

 

这篇关于Crack LeetCode 之 127. Word Ladder的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/824504

相关文章

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Java利用poi实现word表格转excel

《Java利用poi实现word表格转excel》这篇文章主要为大家详细介绍了Java如何利用poi实现word表格转excel,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、每行对象类需要针对不同的表格进行对应的创建。package org.example.wordToEx

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

Python批量调整Word文档中的字体、段落间距及格式

《Python批量调整Word文档中的字体、段落间距及格式》这篇文章主要为大家详细介绍了如何使用Python的docx库来批量处理Word文档,包括设置首行缩进、字体、字号、行间距、段落对齐方式等,需... 目录关键代码一级标题设置  正文设置完整代码运行结果最近关于批处理格式的问题我查了很多资料,但是都没

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

基于Java实现模板填充Word

《基于Java实现模板填充Word》这篇文章主要为大家详细介绍了如何用Java实现按产品经理提供的Word模板填充数据,并以word或pdf形式导出,有需要的小伙伴可以参考一下... Java实现按模板填充wor编程d本文讲解的需求是:我们需要把数据库中的某些数据按照 产品经理提供的 word模板,把数据

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c