leetcode:word-ladder

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

Only one letter can be changed at a time 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 length5.

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

解题思路:

  1. 该题的考点在于广度优先搜索
  2. 设置多个 Hashset 来处理中间值
  3. beginSet 存放开始状态值,endSet 存放结束值,visited 来存放已经被访问过的字符串
  4. 依次取出 beginSet 里的字符串,替换其中的字母。将替换后的字符串与结果集进行比较,若存在于结果集,返回 res,如果不存在于结果集,看看它是否在参数 dict 中,若在,放入 visited 中,同时存入 beginSet 中

代码如下:

public int ladderLength(String start, String end, HashSet<String> dict) {
        // 初始化数据结构
	HashSet<String> beginSet = new HashSet<>();
        HashSet<String> endSet = new HashSet<>();
        HashSet<String> visited = new HashSet<>();

        beginSet.add(start);
        endSet.add(end);
        visited.add(start);

        int res = 1;

	// 循环处理 beginSet
        while(!beginSet.isEmpty() && !endSet.isEmpty() ){

            HashSet<String> temp = new HashSet<>();
            for(String str : beginSet){
                char [] chs = str.toCharArray();
                for(int i = 0; i < chs.length; i++){
                    char old = chs[i];
                    for(char c = 'a'; c <= 'z'; c++){
                        chs[i] = c;
                        String cur = String.valueOf(chs);
                        if(endSet.contains(cur)){
                            return res + 1;
                        }

                        if(!visited.contains(cur) && dict.contains(cur)){
                            temp.add(cur);
                            visited.add(cur);
                        }
                    }
                    chs[i] = old;
                }
            }
            beginSet = temp;
            res++;
        }
        return 0;
    }

转载于:https://my.oschina.net/happywe/blog/3072155

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值