zoukankan      html  css  js  c++  java
  • Word Ladder

    Word Ladder 

    Given two words (start and end), and a dictionary, find the length of shortest transformation sequence from start to end, such that:

    1. Only one letter can be changed at a time
    2. Each intermediate word must exist in the dictionary

    For example,

    Given:
    start = "hit"
    end = "cog"
    dict = ["hot","dot","dog","lot","log"]

    As one shortest transformation is "hit" -> "hot" -> "dot" -> "dog" -> "cog",
    return its length 5.

    Note:

    • Return 0 if there is no such transformation sequence.
    • All words have the same length.
    • All words contain only lowercase alphabetic characters.

    这道题A的略烦,按照提示,应该用BFS,确实用BFS思路比较清晰

    参考:http://blog.csdn.net/yutianzuijin/article/details/12887747

    百度和谷歌了一下,很多人都是直接贴代码,我也是经常这样干,不过上面这篇Blog还可以,照着他的思路我也写了一个BFS

    主要思路

    1.如果有为空的,或者两个相等直接返回0

    2.使用队列,将start入队,遍历队列直到队列为空

    2.1队列头部出队,head将head从第一个字母到最后一个字母分别用a~z进行替换,如果在dict中,没有被使用过,入队

    2.2如果替换过后的单词和end也就是最后一个单词相等,直接返回到这个单词距离+1

    还是文笔太烂~描述不清楚

     1 import java.util.HashMap;
     2 import java.util.LinkedList;
     3 import java.util.Queue;
     4 import java.util.Set;
     5 
     6 //class ListNode {
     7 //      public int val;
     8 //      public ListNode next;
     9 //      ListNode(int x) {
    10 //          val = x;
    11 //          next = null;
    12 //      }
    13 //  }
    14 
    15 public class Solution {
    16     public int ladderLength(String start, String end, Set<String> dict) {
    17         if(null == start || null == end || end.equals(start))
    18             return 0;
    19         if(hasOneWordDiff(start, end))                                            //如果两个只差一个字母返回距离为2
    20             return 2;
    21         //使用BFS,队列
    22         //将开始的单词入队,直到对空为止
    23         Queue<String> queue = new LinkedList<String>();                            //队列
    24         //建议使用hashmap不用hashtable
    25         HashMap<String, Integer> dist = new HashMap<String, Integer>();            //存放到单词的距离
    26         queue.add(start);                                                        //将start元素放到队列中
    27         dist.put(start, 1);                                                        //到start的距离为1
    28         //开始BFS,直到队列为空
    29         while(!queue.isEmpty()){
    30             String head = queue.poll();                                            //队列头部出列
    31             int distTemp = dist.get(head);                                        //start到单词的距离
    32             //System.out.print(head + " " + distTemp);
    33             
    34             for(int i = 0; i < head.length(); i++){                                //从第一个字母开始替换,如果只有一个字母入队
    35                 StringBuffer sb = new StringBuffer(head);
    36                 for(char s = 'a'; s <= 'z'; s++){                                //每个字母替换成26个字母中的一个进行比较
    37                     if(s == head.charAt(i))
    38                         continue;
    39                     sb.setCharAt(i, s);                                            //替换过后,只有一个字母不同,如果有这样的单词,入队
    40                     
    41                     if(sb.toString().equals(end)){                        
    42                         return distTemp + 1;                                        
    43                     }
    44                     if(dict.contains(sb.toString()) && !dist.containsKey(sb.toString())){
    45                         queue.add(sb.toString());                                //入队
    46                         dist.put(sb.toString(), distTemp + 1);
    47                     }
    48                 }
    49             }    
    50         }
    51         return 0;
    52        
    53     }
    54     
    55     /**
    56      * 如果两个单词只有一个字母是不同的返回true,其他返回false
    57      * @param str1
    58      * @param str2
    59      * @return
    60      */
    61     public boolean hasOneWordDiff(String str1, String str2){
    62         int diff = 0;
    63         for(int i = 0; i < str1.length(); i++){
    64             if(str1.charAt(i) != str2.charAt(i)){
    65                 diff++;
    66                 if(diff >= 2)
    67                     return false;                                //超过两个不同直接返回false
    68             }
    69         }
    70         
    71         return diff == 1;
    72     }
    73 }
  • 相关阅读:
    ECS内网穿透
    设置服务器ssh会话时间
    VScode插件
    Linux拷贝U盘文件(命令行)
    打开IDM下载视频时弹出防火墙阻止下载,解决方案
    如何将jmeter.bat命令文件固定到任务栏
    jmeter安装教程
    安装JDK8.0(JDK1.8) & 环境变量配置 & idea中配置java路径
    教你不用任何第三方软件实现任务栏居中
    [Unity优化]gc03:代码优化
  • 原文地址:https://www.cnblogs.com/luckygxf/p/4143893.html
Copyright © 2011-2022 走看看