Online Judge | Problem Set | Authors | Online Contests | User | ||||||
---|---|---|---|---|---|---|---|---|---|---|
Web Board Home Page F.A.Qs Statistical Charts | Current Contest Past Contests Scheduled Contests Award Contest |
题解 GarsiaWachs算法题意: 石子合并问题, 将相邻两堆石子合并, 每次得分是合并成新的一堆石子个数, 最后累加最小值. 解题思路: 1. 这类题目一开始想到是DP, 设dp[i][j]表示第i堆石子到第j堆石子合并最小得分. 状态方程: dp[i][j] = min(dp[i][k]+dp[k+1][j]+sum[j]-sum[i-1]); sum[i]表示第1到第i堆石子总和. 递归记忆化搜索即可. 2. 不过此题有些不一样, 1<=n<=50000范围特大, dp[50000][50000]开不到这么大数组. 问题分析: (1). 假设我们只对3堆石子a,b,c进行比较, 先合并哪2堆, 使得得分最小. score1 = (a+b) + ( (a+b)+c ) score2 = (b+c) + ( (b+c)+a ) 再次加上score1 <= score2, 化简得: a <= c, 可以得出只要a和c的关系确定, 合并的顺序也确定. (2). GarsiaWachs算法, 就是基于(1)的结论实现.找出序列中满足stone[i-1] <= stone[i+1]最小的i, 合并temp = stone[i]+stone[i-1], 接着往前面找是否 有满足stone[j] > temp, 把temp值插入stone[j]的后面(数组的右边). 循环 这个过程一直到只剩下一堆石子结束. (3). 为什么要将temp插入stone[j]的后面, 可以理解为(1)的情况 从stone[j+1]到stone[i-2]看成一个整体 stone[mid],现在stone[j], stone[mid], temp(stone[i-1]+stone[i-1]), 情况因为temp < stone[j], 因此不管怎样都是stone[mid]和temp先合并, 所以讲temp值插入stone[j] 的后面是不影响结果. http://blog.csdn.net/u011328276/article/details/9669531 Followed by: Post your reply here: |
All Rights Reserved 2003-2013 Ying Fuchen,Xu Pengcheng,Xie Di
Any problem, Please Contact Administrator