Word Ladder

Word Ladder

  Total Accepted: 4645  Total Submissions: 28613 My Submissions

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.

开始用DFS,无奈TLE,  也不奇怪,有很多重复的计算,后来用BFS顺利解决.

public class Solution {

    public int ladderLength(String start, String end, HashSet<String> dict) {
        int min = 0;
        Set<String> visit = new HashSet<>();
        Set<String> endSet = neighbors(end,dict);
        Queue<String> queue = new LinkedList<>();
        queue.add(start);
        while(!queue.isEmpty()){
            Queue<String> subQ = new LinkedList<>();
            while(!queue.isEmpty()){
                String s = queue.poll();
                if(visit.contains(s)) continue;
                visit.add(s);
                if(endSet.contains(s)) return min+2;
                Set<String> neighbors = neighbors(s,dict);
                for(String str: neighbors) subQ.add(str);
            }
            min++;
            queue = subQ;
        }
        return 0;
    }
    
    private  Set<String> neighbors(String a, Set<String> dict){
        Set<String> set = new HashSet<>();
        for(int i = 0 ; i < a.length(); i++){
            for(int j = 0; j < 26; j++){
                char[] arr = a.toCharArray();
                arr[i] = (char)('a'+j);
                String temp = new String(arr);
                if(dict.contains(temp)) set.add(temp);
            }
        }
        return set;
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值