您的位置:首页 > 其它

uva 10003 - Cutting Sticks

2014-08-07 21:04 197 查看
刚做这个题的时候,dp(i,j)表示从i到j的范围,但是边界处理不好,例如4 , 5 挨着cut的时候,后来换成dp(i,j)表示要cut的位置的序号从i到j

/*************************************************************************
> File Name: 10003.cpp
> Author: bxf
> Mail: bbb546754186@vip.qq.com
> Created Time: 2014年08月07日 星期四 19时50分57秒
************************************************************************/

#include <iostream>
#include <cstring>
#include <cstdlib>
#include <set>
#include <cstdio>
#include <string>
#include <vector>
#include <map>
#include <cmath>
#include <algorithm>
#define INF 0xfffffff
#define maxn 1000 + 10
#define ll long long

using namespace std;
int s[60];
int dp[maxn][maxn];
int n;
int DP(int x, int y)
{
int &ans = dp[x][y];
if(ans != -1) return ans;
if(y-x <= 1)
return ans = 0;
ans = INF;
for(int i = x+1; i < y; ++i)
{
ans = min(ans, DP(x, i)+DP(i, y)+s[y]-s[x]);
}
return ans;
}
int main()
{
int length;
while(scanf("%d", &length) != EOF)
{
if(!length) break;
scanf("%d", &n);
s[0] = 0; s[n+1] = length;
for(int i = 1; i <= n; ++i)
scanf("%d", &s[i]);
memset(dp, -1, sizeof(dp));
printf("The minimum cutting is %d.\n", DP(0, n+1));
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: