美文网首页计算机
Leetcode - Evaluate Division

Leetcode - Evaluate Division

作者: Richardo92 | 来源:发表于2016-09-24 04:45 被阅读143次

My code:

import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;

public class Solution {
    public double[] calcEquation(String[][] equations, double[] values, String[][] queries) {
        
        HashMap<String, Map<String, Double>> map = new HashMap<>();
        for (int i = 0; i < equations.length; i++) {
            insert(equations[i][0], equations[i][1], values[i], map);
            insert(equations[i][1], equations[i][0], 1.0 / values[i], map);
        }
        
        double[] arr = new double[queries.length];
        for (int i = 0; i < queries.length; i++) {
            Double ret = query(queries[i][0], queries[i][1], map, new HashSet<String>());
            if (ret == null) {
                arr[i] = -1.0;
            }
            else {
                arr[i] = ret;
            }
        }
        
        return arr;
    }
    
    private void insert(String num, String denum, double result, Map<String, Map<String, Double>> map) {
        if (!map.containsKey(num)) {
            map.put(num, new HashMap<String, Double>());
        }
        map.get(num).put(denum, result);
    }
    
    private Double query(String num, String denum, Map<String, Map<String, Double>> map, Set<String> set) {
        String key = num + "/" + denum;
        if (set.contains(key)) {
            return null;
        }
        else if (!map.containsKey(num) || !map.containsKey(denum)) {
            return null;
        }
        
        Map<String, Double> sub = map.get(num);
        if (sub.containsKey(denum)) {
            return sub.get(denum);
        }
        
        set.add(key);
        for (String curr : sub.keySet()) {
            Double ret = query(curr, denum, map, set);
            if (ret != null) {
                return sub.get(curr) * ret;
            }
        }
        set.remove(key);
        return null;
    }
}

reference:
https://discuss.leetcode.com/topic/58321/java-ac-solution-with-explanation/2

的确和 reconstruct iterary 很像。

先构建一个有向图,然后 dfs, backtracking
找到我们要找的。

Anyway, Good luck, Richardo! -- 09/23/2016

相关文章

网友评论

    本文标题:Leetcode - Evaluate Division

    本文链接:https://www.haomeiwen.com/subject/yjkxyttx.html