-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy path0120-triangle.cpp
21 lines (21 loc) · 1.18 KB
/
0120-triangle.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class Solution{
public:
int minimumTotal(vector<vector<int>>& triangle){
for(int i = 0; i < triangle.size() - 1; i++){
for(int k = 0; k < triangle[i + 1].size(); k++){
if(k == 0){
triangle[i + 1][0] = triangle[i + 1][0] + triangle[i][0];
}
else{
if(k == triangle[i + 1].size() - 1){
triangle[i + 1][k] = triangle[i + 1][k] + triangle[i][k - 1];
}
else{
triangle[i + 1][k] = triangle[i + 1][k] + min(triangle[i][k - 1], triangle[i][k]);
}
}
}
}
return *min_element(triangle[triangle.size() - 1].begin(), triangle[triangle.size() - 1].end());
}
};