单词接龙(java)_127

在这里插入图片描述

package com.tuling.algomiter.bfs;

import java.util.*;

/**
 * Author: sl
 * date:   2022/11/1
 * time:   1:31 下午
 */
public class wordLadder_127 {
    public static void main(String[] args) {
        String start = "hit";
        String end = "cog";
        List<String> worldList = new ArrayList<>();
        worldList.add("hot");
        worldList.add("dot");
        worldList.add("dog");
        worldList.add("lot");
        worldList.add("log");
        worldList.add("cog");
        System.out.println(new wordLadder_127().ladderLength(start, end, worldList));
    }
    public int ladderLength(String beginWord, String endWord, List<String> wordList) {
        // 创建set 方便获取值
        Set<String> worldDic = new HashSet<>(wordList);
        if (wordList.size() == 0 || !worldDic.contains(endWord)){
            return 0;
        }
        // 移除开始的
        worldDic.remove(beginWord);

        //初始化队列
        Queue<String> queue = new LinkedList<>();
        queue.offer(beginWord);
        // 记录访问过的单词
        Set<String> visited = new HashSet<>();
        visited.add(beginWord);
        // 队列不为空开始循环
        int step = 1;
        while (!queue.isEmpty()){
            // 获取队列大小
            int currentSize = queue.size();
            for (int i = 0;i < currentSize;i++){
                // 取出当前循环的单词
                String currentWorld = queue.poll();
                if (changeOneWorld(currentWorld,endWord,queue,visited,worldDic)){
                    return step + 1;
                }
            }
            step++;
        }
        return 0;
    }

    private boolean changeOneWorld(String currentWorld, String endWord, Queue<String> queue, Set<String> visited, Set<String> worldDic) {
        // 转换成char 型数组
        char[] charArray = currentWorld.toCharArray();
        // 每次只改变其中一个字符 循环开始修改字符
        for (int i = 0; i < endWord.length(); i++) {
            // 获取修改前的字符
            char originChar = charArray[i];
            // 开始修改单个字符
            for (char k = 'a';k < 'z';k++){
                // 是自己跳过
                if (k == originChar){
                    continue;
                }
                // 修改单个字符
                charArray[i] = k;
                // 重新转换为 String
                String newWorld = String.valueOf(charArray);
                // 新组合符合条件
                if (worldDic.contains(newWorld)){
                    // 结束循环条件
                    if (newWorld.equals(endWord)){
                        return true;
                    }
                    // 符合条件的情况
                    if (!visited.contains(newWorld)){
                        queue.add(newWorld);
                        visited.add(newWorld);
                    }
                }
            }
            // 恢复
            charArray[i] = originChar;
        }
        return false;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单词接龙是一个游戏,旨在通过更改一个字母来逐步转换一个单词成为另一个指定的单词。规则包括: 1. 可用于接龙单词首字母必须与前一个单词的尾字母相同。 2. 当存在多个首字母相同的单词时,取长度最长的单词。如果长度也相等,则取词典序最小的单词。 3. 已经参与接龙单词不能重复使用。 对于给定的一组由小写字母组成的单词数组和指定的起始单词和结束单词,我们需要进行单词接龙,并输出最长的单词串,其中单词串是由单词拼接而成,中间没有空格。如果不存在这样的转换序列,则返回0。 例如,对于输入的例子 beginWord = "hit",endWord = "cog",wordList = ["hot", "dot", "dog", "lot", "log"],我们可以进行以下单词接龙序列: "hit" -> "hot" -> "dot" -> "dog" -> "cog"。在这个例子中,最长的单词串为"hit" -> "hot" -> "dot" -> "dog" -> "cog"。 请注意,以上例子只是为了说明单词接龙的概念和规则,并不是针对Python编程的具体实现。具体的实现方法可以使用广度优先搜索 (BFS) 或双向BFS等算法来解决。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [python题目55:单词接龙](https://blog.csdn.net/m0_60741207/article/details/121528418)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [127. 单词接龙(Python)](https://blog.csdn.net/JulyLi2019/article/details/106610034)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值