标签:
3 1 2 3 7 13 7 8 16 21 4 18
9 239
#include <cstdio> #include <iostream> #include <sstream> #include <cmath> #include <cstring> #include <cstdlib> #include <string> #include <vector> #include <map> #include <set> #include <queue> #include <stack> #include <algorithm> using namespace std; #define ll long long #define _cle(m, a) memset(m, a, sizeof(m)) #define repu(i, a, b) for(int i = a; i < b; i++) #define repd(i, a, b) for(int i = b; i >= a; i--) #define sfi(n) scanf("%d", &n) #define pfi(n) printf("%d\n", n) #define sfi2(n, m) scanf("%d%d", &n, &m) #define pfi2(n, m) printf("%d %d\n", n, m) #define pfi3(a, b, c) printf("%d %d %d\n", a, b, c) #define MAXN 205 const int INF = 0x3f3f3f3f; int dp[MAXN][MAXN]; int a[MAXN]; int sum[MAXN]; int main() { int n; while(~sfi(n)) { _cle(dp, 0x3f); sum[0] = 0; repu(i, 0, n) { sfi(a[i]); dp[i][i] = 0; sum[i + 1] = sum[i] + a[i]; } for(int i = n - 1; i >= 0; i--) repu(j, i, n) { repu(k, i, j) dp[i][j] = min(dp[i][j], (dp[i][k] + dp[k + 1][j]) + sum[j + 1] - sum[i]); } pfi(dp[0][n - 1]); } return 0; }
标签:
原文地址:http://www.cnblogs.com/sunus/p/4773954.html