uva 10003(动态规划起步第四天 矩阵连乘)

类似矩阵连乘的一道题,很简单DP[i][j]表示区间i,j最少费用,

状态转移为DP[i][j] = min{DP[i][k],DP[k][j]} + a[j] - a[i];

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <algorithm>
 5 
 6 #define REP(i,N) for (int i = 0;i < (N);i++)
 7 #define REP_1(i,N) for (int i = 1;i < (N);i++)
 8 #define REP_2(i,be,en) for (int i = (be);i < (en);i++)
 9 #define DWN(i,N) for (int i = N;i >= 0;i--)
10 #define INF 0x3f3f3f3f
11 #define MAXN 55
12 
13 using namespace std;
14 int L,N;
15 int a[MAXN];
16 int DP[MAXN][MAXN];
17 
18 int dp(int be,int en) {
19     if (be >= en - 1) return 0;
20     if (DP[be][en]) return DP[be][en];
21     int MIN = INF;
22     REP_2(i,be + 1,en){
23         MIN = min(MIN,dp(be,i) + dp(i,en));
24     }
25     return DP[be][en] = MIN + a[en] - a[be];
26 }
27 
28 int main () {
29     //freopen("1.txt","r",stdin);
30     while (cin >> L,L) {
31         cin >> N;
32         memset(DP,0,sizeof(DP));
33         REP_1(i,N + 1) {
34             cin >> a[i];
35         }
36         a[0] = 0;a[N + 1] = L;
37         printf("The minimum cutting is %d.\n",dp(0,N + 1));
38     }
39 }

 

posted @ 2015-02-17 18:32  闪光阳  阅读(208)  评论(0编辑  收藏  举报