forked from onkardighe/Leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
_0120_Triangle.java
93 lines (77 loc) · 2.02 KB
/
_0120_Triangle.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// https://leetcode.com/problems/triangle/import java.util.*;
import java.util.*;
public class _0120_Triangle
{
public static void main(String[] args)
{
int[][] tri = {
{2},
{3, 4},
{6, 5, 7},
{4, 1, 8, 3}
};
// converting Array to List
List<List<Integer>> arr = new ArrayList<>();
for(int i = 0; i < tri.length; i++)
{
arr.add(i, new ArrayList<Integer>());
for(int j = 0; j < tri[i].length; j++)
{
arr.get(i).add(j, tri[i][j]);
}
}
Solution0120 obj = new Solution0120();
System.out.println(obj.minimumTotal(arr));
}
}
// Ans : -3
// 1
//-5 -2
// 3 6 1
//-1 2 4 -3
class Solution0120 {
Integer[][] memo;
public int minimumTotal(List<List<Integer>> triangle)
{
int n = triangle.size();
memo = new Integer[n][n];
int ans = dfs(triangle, 0, 0);
return ans;
}
public int dfs(List<List<Integer>> tri, int row, int col)
{
if(row == tri.size()-1)
{
return tri.get(row).get(col);
}
// check for backUp
if(memo[row+1][col] != null)
{
int left = memo[row+1][col];
int right;
if(memo[row+1][col+1] == null)
{
right = dfs(tri, row+1, col+1);
}
else
{
right = memo[row+1][col+1];
}
int ans = tri.get(row).get(col) + Integer.min(left, right);
memo[row][col] = ans;
return ans;
}
else
{
int left = dfs(tri, row+1, col);
int right = dfs(tri, row+1, col+1);
int ans = Integer.min(left, right) + tri.get(row).get(col);
memo[row][col] = ans ;
return ans;
}
}
}
//-1 2 4 -3
// 3 6 1
//-5 -2
// 1