博客
关于我
力扣127
阅读量:175 次
发布时间:2019-02-28

本文共 2753 字,大约阅读时间需要 9 分钟。

为了解决这个问题,我们需要在给定的字典中找到一个单词,使其与给定的单词只相差一个字母,并找到最短的转换路径。我们可以使用图的广度优先搜索(BFS)方法来实现这一点。

方法思路

  • 问题分析:我们需要找到一个单词,使其与给定的单词只相差一个字母。如果存在这样的单词,我们需要找到最短的转换路径。

  • 图的表示:将每个单词视为图中的一个节点,边的连接条件是两个单词只相差一个字母。

  • 广度优先搜索(BFS):使用BFS进行图的遍历,这样可以找到从开始单词到结束单词的最短路径。

  • 辅助类和数据结构:使用辅助类存储单词及其层数,哈希集合记录已访问的单词,二维数组记录单词之间的转换关系。

  • 解决代码

    package Leetcode;import java.util.*;public class Demo127 {    class LevelWord {        String word;        int level;        public LevelWord(String word, int level) {            this.word = word;            this.level = level;        }    }    public int length2(String beginWord, String endWord, List
    wordList) { int endIndex = wordList.indexOf(endWord); if (endIndex == -1) { return 0; } if (!wordList.contains(beginWord)) { wordList.add(beginWord); } boolean[][] adjacencyMatrix = new boolean[wordList.size()][wordList.size()]; HashMap
    visited = new HashMap<>(); for (int i = 0; i < wordList.size(); i++) { for (int j = 0; j < i; j++) { if (hasPath(wordList.get(i).toCharArray(), wordList.get(j).toCharArray())) { adjacencyMatrix[i][j] = adjacencyMatrix[j][i] = true; } } visited.put(wordList.get(i), false); } Queue
    queue = new LinkedList<>(); queue.add(new LevelWord(beginWord, 0)); visited.put(beginWord, true); while (!queue.isEmpty()) { LevelWord temp = queue.poll(); if (temp.word.equals(endWord)) { return temp.level + 1; } int currentIndex = wordList.indexOf(temp.word); List
    nextWords = new ArrayList<>(); for (int i = 0; i < wordList.size(); i++) { if (adjacencyMatrix[currentIndex][i]) { nextWords.add(wordList.get(i)); } } for (String nextWord : nextWords) { if (!visited.get(nextWord)) { visited.put(nextWord, true); queue.add(new LevelWord(nextWord, temp.level + 1)); } } } return 0; } public boolean hasPath(char[] chars1, char[] chars2) { int diff = 0; for (int i = 0; i < chars1.length; i++) { if (chars1[i] != chars2[i]) { diff++; if (diff > 1) { return false; } } } return diff == 1; }}

    代码解释

  • 辅助类 LevelWord:用于存储当前处理的单词及其层数,层数表示从开始单词到该单词的步骤数。

  • length2 方法:主要处理逻辑,包括初始化字典中的单词,创建二维数组记录转换关系,使用BFS遍历图,找到最短路径。

  • hasPath 方法:判断两个单词是否只相差一个字母。

  • BFS 遍历:从开始单词出发,逐层扩展,找到与结束单词相差一个字母的最短路径。

  • 通过这种方法,我们可以高效地找到字典中与给定单词只相差一个字母的单词,并返回最短的转换距离。

    转载地址:http://xtec.baihongyu.com/

    你可能感兴趣的文章
    mysql列转行函数是什么
    查看>>
    mysql创建函数报错_mysql在创建存储函数时报错
    查看>>
    mysql创建数据库和用户 并授权
    查看>>
    mysql创建数据库指定字符集
    查看>>
    MySql创建数据表
    查看>>
    MySQL创建新用户以及ERROR 1396 (HY000)问题解决
    查看>>
    MySQL创建用户与授权
    查看>>
    MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
    查看>>
    MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
    查看>>
    mysql初始密码错误问题
    查看>>
    MySQL删除数据几种情况以及是否释放磁盘空间【转】
    查看>>
    Mysql删除重复数据通用SQL
    查看>>
    mysql判断某一张表是否存在的sql语句以及方法
    查看>>
    mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
    查看>>
    mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
    查看>>
    mysql加强(2)~单表查询、mysql查询常用的函数
    查看>>
    mysql加强(3)~分组(统计)查询
    查看>>
    mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
    查看>>
    mysql加强(5)~DML 增删改操作和 DQL 查询操作
    查看>>
    mysql加强(6)~子查询简单介绍、子查询分类
    查看>>