-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path1130.cpp
More file actions
68 lines (67 loc) · 1.92 KB
/
Copy path1130.cpp
File metadata and controls
68 lines (67 loc) · 1.92 KB
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
class Solution {
public:
int dp[45][45][2];
Solution(){
memset(dp,-1,sizeof(dp));
}
pair<int,int> mcm(vector<int>& arr, int i, int j){//0 to n-1
if(dp[i][j][0]!=-1)
return {dp[i][j][0],dp[i][j][1]};
if(i==j){
dp[i][j][0] = 0;
dp[i][j][1] = arr[i];
return {0,arr[i]};
}
int ans = INT_MAX;
int val = INT_MAX;
for(int k=i; k<j;k++){
auto left = mcm(arr,i,k);
auto right = mcm(arr,k+1,j);
int sum = left.first + right.first + left.second*right.second;
int big = max(left.second,right.second);
if(ans>sum || (ans==sum && big<val)){
ans = sum;
val = big;
}
}
dp[i][j][0] = ans;
dp[i][j][1] = val;
return {ans,val};
}
int mctFromLeafValues(vector<int>& arr) {
auto res = mcm(arr,0,arr.size()-1);
return res.first;
}
};
class Solution {
public:
int dp[45][45][2];
Solution(){
memset(dp,0,sizeof(dp));
}
int mctFromLeafValues(vector<int>& arr) {
int n = arr.size();
for(int i=0; i<n; i++){
dp[i][i][0] = 0;
dp[i][i][1] = arr[i];
}
for(int length=2; length<=n; length++){
for(int i=0; i<n-length+1; i++){
int j = i+length-1;
int ans = INT_MAX;
int val = INT_MAX;
for(int k=i; k<j; k++){
int sum = dp[i][k][0] + dp[k+1][j][0] + dp[i][k][1]*dp[k+1][j][1];
int big = max(dp[i][k][1],dp[k+1][j][1]);
if(ans>sum || (ans==sum && big<val)){
ans = sum;
val = big;
}
}
dp[i][j][0] = ans;
dp[i][j][1] = val;
}
}
return dp[0][n-1][0];
}
};