美文网首页
Matrix DP - 120. Triangle

Matrix DP - 120. Triangle

作者: Super_Alan | 来源:发表于2018-04-06 05:05 被阅读0次

    https://leetcode.com/problems/triangle/description/

    代码:

    // assume triangle is ArrayList<ArrayList<Integer>>, so list.get(index) will be O(1) operation
    // 不要纠结 List 的 get 操作可能是 O(n) runtime; 既然是实现某项功能,使用正确的数据结构是很重要的;如果是该function是用来作 api 使用的,那么数据结构可能是json,需要做预处理。
    // 面试的时候,List 数据结构不同,所需要的runtime 也不同就可以了。
    
    class Solution {
        public int minimumTotal(List<List<Integer>> triangle) {
            int[] dp = new int[triangle.size() + 1];
            
            for (int i = triangle.size() - 1; i >= 0; i--) {
                List<Integer> list = triangle.get(i);
                for (int j = 0; j < list.size(); j++) {
                    dp[j] = list.get(j) + Math.min(dp[j], dp[j + 1]);
                }
            }
            return dp[0];
        }
    }
    

    相关文章

      网友评论

          本文标题:Matrix DP - 120. Triangle

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