• codevs1048石子归并


    codevs1048 石子归并

     时间限制: 1 s
     空间限制: 128000 KB
     题目等级 : 黄金 Gold
    传送门  http://codevs.cn/problem/1048/
    题目描述 Description

    有n堆石子排成一列,每堆石子有一个重量w[i], 每次合并可以合并相邻的两堆石子,一次合并的代价为两堆石子的重量和w[i]+w[i+1]。问安排怎样的合并顺序,能够使得总合并代价达到最小。

    输入描述 Input Description

    第一行一个整数n(n<=100)

    第二行n个整数w1,w2...wn  (wi <= 100)

    输出描述 Output Description

    一个整数表示最小合并代价

    样例输入 Sample Input

    4

    4 1 1 4

    样例输出 Sample Output

    18

    #include<iostream>
    #include<cstdio>
    #define MAXN 105
    #define INF 0x3f3f3f3f
    using namespace std;
    int max(int x,int y){
        return x>y?y:x;    
    } 
    int n,w[MAXN],a[MAXN][MAXN],z[MAXN];
    int main()
    {
        cin>>n;
        for(int i=1;i<=n;++i)
            scanf("%d",&z[i]),w[i]=w[i-1]+z[i];
        for(int z=1;z<n;++z)
        {
            for(int i=1;i+z<=n;++i)
            {
                int j=i+z,sum=w[j]-w[i-1];
                a[i][j]=INF;
                for(int zz=i;zz<j;++zz)
                {
                    a[i][j]=min(a[i][j],a[i][zz]+a[zz+1][j]+sum);
                }
            }
        }
        printf("%d",a[1][n]);
    }
  • 相关阅读:
    拓扑排序
    最少硬币问题(无穷硬币)
    第三届蓝桥杯预赛
    矩形嵌套
    《心术》影评
    区间选点问题
    [转贴] 游戏服务器架构
    D3DXPlaneFromPoints 函数
    内存池实现
    [转]MMORPG游戏服务器端的设计
  • 原文地址:https://www.cnblogs.com/dsrdsr/p/8848982.html
Copyright © 2020-2023  润新知