nyoj737 石子合并(一) 区间DP
2017-02-08 10:42
281 查看
dp[x][y]表示合并[x, y]区间的石子的最小花费,将区间长度递增枚举即可。
AC代码:
#include<cstdio>
#include<algorithm>
using namespace std;
const int inf = 1 << 30;
const int maxn = 200 + 5;
int dp[maxn][maxn], a[maxn], sum[maxn];
int solve(int n){
for(int i = 1; i < n; ++i) dp[i][i] = 0;
for(int i = 2; i <= n; ++i)
for(int j = 1; j <= n - i + 1; ++j){
int x = j, y = j + i - 1;
dp[x][y] = inf;
for(int k = j; k < y; ++k){
dp[x][y] = min((dp[x][k] + dp[k + 1][y]) + sum[y] - sum[x - 1], dp[x][y]);
}
}
return dp[1]
;
}
int main(){
int n;
while(scanf("%d", &n) == 1){
sum[0] = 0;
for(int i = 1; i <= n; ++i) {
scanf("%d", &a[i]);
sum[i] = sum[i - 1] + a[i];
}
printf("%d\n", solve(n));
}
return 0;
}
如有不当之处欢迎指出!
AC代码:
#include<cstdio>
#include<algorithm>
using namespace std;
const int inf = 1 << 30;
const int maxn = 200 + 5;
int dp[maxn][maxn], a[maxn], sum[maxn];
int solve(int n){
for(int i = 1; i < n; ++i) dp[i][i] = 0;
for(int i = 2; i <= n; ++i)
for(int j = 1; j <= n - i + 1; ++j){
int x = j, y = j + i - 1;
dp[x][y] = inf;
for(int k = j; k < y; ++k){
dp[x][y] = min((dp[x][k] + dp[k + 1][y]) + sum[y] - sum[x - 1], dp[x][y]);
}
}
return dp[1]
;
}
int main(){
int n;
while(scanf("%d", &n) == 1){
sum[0] = 0;
for(int i = 1; i <= n; ++i) {
scanf("%d", &a[i]);
sum[i] = sum[i - 1] + a[i];
}
printf("%d\n", solve(n));
}
return 0;
}
如有不当之处欢迎指出!
相关文章推荐
- nyoj737 石子合并 区间dp
- 石子合并 nyoj737 区间dp
- NYOJ737 石子合并(区间DP)
- nyoj737 区间dp(合并石子)
- nyoj737 石子合并(一)(区间dp)
- 区间dp(石子合并and括号匹配)
- P1880 [NOI1995]石子合并(区间dp)
- [nyoj737]石子归并(区间dp入门题)
- nyoj 737 石子合并(一)(区间DP)
- (区间dp)南阳理工 acm 737 石子合并(一)
- 【tyvj】【区间dp】石子合并
- nyoj737石子合并(一)【区间dp】
- NYOJ 737 石子合并(一)(区间dp)
- 合并石子 (区间覆盖DP)
- 洛谷OJ - P1880 - 石子合并(区间DP)
- 石子合并【区间dp】
- [NYIST737]石子合并(一)(区间dp)
- nyist 737 石子合并(一)(区间dp)
- ADV-229 合并石子 —— 区间dp引申(java)
- 区间DP问题(矩阵连乘,石子合并,括号匹配)