269. Alien Dictionary

Hard
no need to copy questions, you'll check LeetCode anyway
第一,构图,构造 degree
第二,topological sort

class Solution {
    public String alienOrder(String[] words) {

        StringBuilder res = new StringBuilder();
        Map indegree = new HashMap<>();
        Map> graph = new HashMap<>();

        for (String word : words){
            for (char c : word.toCharArray()){
                if (!graph.containsKey(c)){
                    graph.put(c, new HashSet());
                }
                if (!indegree.containsKey(c)){
                    indegree.put(c, 0);
                }
            }
        }

        for (int i = 0; i < words.length - 1; i++){
            String curt = words[i];
            String next = words[i + 1];
            int lenCurt = curt.length();
            int lenNext = next.length();
            int len = Math.min(lenCurt, lenNext);
            for (int j =  0; j < len; j++){
                char c1 = curt.charAt(j);
                char c2 = next.charAt(j);   
                if (c1 != c2){
                    HashSet set = graph.get(c1);
                    if (!set.contains(c2)){
                        set.add(c2);
                        indegree.put(c2, indegree.get(c2) + 1);
                    } 
                    break;
                }

            }
        }

        Queue queue = new LinkedList<>();
        for (Character c : indegree.keySet()){
            if (indegree.get(c) == 0){
                queue.offer(c);
            }
        }

        while (!queue.isEmpty()){
            char c = queue.poll();
            res.append(c);
            for (Character nei : graph.get(c)){
                indegree.put(nei, indegree.get(nei) - 1);
                if (indegree.get(nei) == 0){
                    queue.offer(nei);
                }
            }
        }

        if (res.length() != graph.size()){
            return "";
        }
        return res.toString();
    }
}

你可能感兴趣的:(269. Alien Dictionary)