uva 10304 Optimal Binary Search Tree 最优二叉树编码 区间dp

题意:给出一组频率,让你建立一个二叉树,计算每个节点的频率×层数,使得这个值最小,问最小的值是多少。


设f(i, j)表示序列区间(i, j)的数构成的一棵最优二叉查找树的值,
   当枚举根节点ek时,它的左子树(wi,wi+1,..,wk-1)的所有节点的深度都会增加1,
   那么左子树增加sum(w1,w2,...wk-1)
   右子树(ek+1, ek+2,..ej)的值也会增加sum(ek+1,ek+2,...,ej).
   可以看出,那么总共会增加sum(i, j) - wk

---fromshangde大神

状态转移方程就是:dp[i][j] = min(dp[i][k - 1] + dp[k + 1] + sum(i, j) - a[i])

代码:

/*
*  Author:      illuz <iilluzen[at]gmail.com>
*  Blog:        http://blog.csdn.net/hcbbt
*  File:        uva10304.cpp
*  Create Date: 2013-11-12 22:32:08
*  Descripton:  invertel dp 
*/

#include <cstdio>
#include <cstring>

#define min(a, b) ((a) < (b) ? (a) : (b))

const int MAXN = 210;
int n, a[MAXN], sum[MAXN];
int dp[MAXN][MAXN];

int main() {
	while (scanf("%d", &n) != EOF) {
		for (int i = 1; i <= n; i++) {
			scanf("%d", &a[i]);
			sum[i] = sum[i - 1] + a[i];
		}

		for (int d = 2; d <= n; d++)
			for (int l = 1; l + d - 1 <= n; l++) {
				int r = l + d - 1;
				dp[l][r] = 0x7ffffff;
				for (int i = l; i <= r; i++)
					dp[l][r] = min(dp[l][r], dp[l][i - 1] + dp[i + 1][r] + sum[r] - sum[l - 1] - a[i]);
			}

		printf("%d\n", dp[1][n]);
	}
	return 0;
}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值