bzoj 4446: [Scoi2015]小凸玩密室【树形dp】
神仙题!参考https://www.cnblogs.com/wfj2048/p/7695711.html
注意完全二叉树不是满二叉树!!!!
设g[u][j]为u遍历完子树到深度为i-1的祖先的兄弟的最小花费,f[u][i]为u遍历完子树到深度为i的祖先的最小花费,显然g的作用是更新f
当u为叶子的时候,g直接用长度*点权更新即可,否则就是从先走左儿子或者先走右儿子中取min,也就是g[u][i]=min(a[ls]*b[ls]+g[ls][de[u]+1]+g[rs][i],a[rs]*b[rs]+g[rs][de[u]+1]+g[ls1][i]),然后这里有一个特殊情况,是u下面只有n一个儿子,那么就只用直接转移左儿子即可
f同理
#include<iostream>
#include<cstdio>
using namespace std;
const int N=200005;
int n,de[N];
long long a[N],b[N],f[N][20],g[N][20],dis[N],ans;
int read()
{
	int r=0,f=1;
	char p=getchar();
	while(p>'9'||p<'0')
	{
		if(p=='-')
			f=-1;
		p=getchar();
	}
	while(p>='0'&&p<='9')
	{
		r=r*10+p-48;
		p=getchar();
	}
	return r*f;
}
int main()
{
	n=read();
	for(int i=1;i<=n;i++)
		a[i]=read();
	de[1]=1;
	for(int i=2;i<=n;i++)
		b[i]=read(),de[i]=de[i>>1]+1,dis[i]=dis[i>>1]+b[i];
	for(int u=n;u>=1;u--)
		for(int i=2;i<=de[u];i++)
		{
			if((u<<1)>n)
				g[u][i]=(dis[u]+dis[(u>>(de[u]-i))^1]-2*dis[u>>(de[u]-i+1)])*a[(u>>(de[u]-i))^1];
			else if((u<<1)==n)
				g[u][i]=a[n]*b[n]+g[n][i];
			else
				g[u][i]=min(a[u<<1]*b[u<<1]+g[u<<1][de[u]+1]+g[u<<1|1][i],a[u<<1|1]*b[u<<1|1]+g[u<<1|1][de[u]+1]+g[u<<1][i]);
		}
	for(int u=n;u>=1;u--)
		for(int i=0;i<=de[u];i++)
		{
			if((u<<1)>n)
				f[u][i]=i?(dis[u]-dis[u>>(de[u]-i)])*a[u>>(de[u]-i)]:0;
			else if((u<<1)==n)
				f[u][i]=a[n]*b[n]+f[n][i];
			else
				f[u][i]=min(a[u<<1]*b[u<<1]+g[u<<1][de[u]+1]+f[u<<1|1][i],a[u<<1|1]*b[u<<1|1]+g[u<<1|1][de[u]+1]+f[u<<1][i]);
		}
	ans=f[1][0];
	for(int i=2;i<=n;i++)
	{
		long long nw=f[i][de[i]-1];
		for(int x=i;x>1;x>>=1)
			nw+=(x^1)>n?(a[x>>2]*b[x>>1]):(a[x^1]*b[x^1]+f[x^1][de[x>>1]-1]);
		ans=min(ans,nw);
	}
	printf("%lld\n",ans);
	return 0;
}
bzoj 4446: [Scoi2015]小凸玩密室【树形dp】的更多相关文章
- BZOJ.4446.[SCOI2015]小凸玩密室(树形DP)
		BZOJ LOJ 洛谷 (下面点亮一个灯泡就说成染色了,感觉染色比较顺口... 注意完全二叉树\(\neq\)满二叉树,点亮第一个灯泡\(\neq\)第一次点亮一号灯泡,根节点应该就是\(1\)... ... 
- [BZOJ4446]SCoi2015 小凸玩密室 树形DP(烧脑高能预警)
		4446: [Scoi2015]小凸玩密室 Time Limit: 10 Sec Memory Limit: 128 MB Description 小凸和小方相约玩密室逃脱,这个密室是一棵有n个节点 ... 
- bzoj 4446: [Scoi2015]小凸玩密室
		Description 小凸和小方相约玩密室逃脱,这个密室是一棵有n个节点的完全二叉树,每个节点有一个灯泡.点亮所有灯 泡即可逃出密室.每个灯泡有个权值Ai,每条边也有个权值bi.点亮第1个灯泡不需要 ... 
- BZOJ4446:[SCOI2015]小凸玩密室(树形DP)
		Description 小凸和小方相约玩密室逃脱,这个密室是一棵有n个节点的完全二叉树,每个节点有一个灯泡.点亮所有灯泡即可逃出密室. 每个灯泡有个权值Ai,每条边也有个权值bi.点亮第1个灯泡不需要 ... 
- LUOGU P4253 [SCOI2015]小凸玩密室(树形dp)
		传送门 解题思路 玄学树形\(dp\),题目描述极其混乱...看错了两次题,设首先根据每次必须点完子树里的灯才能点别的,那么点灯情况只有两种,第一种是点到某一个祖先,第二种是点到某一个祖先的兄弟.所以 ... 
- BZOJ 4443: [Scoi2015]小凸玩矩阵 最大流
		4443: [Scoi2015]小凸玩矩阵 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4443 Description 小凸和小方是好 ... 
- bzoj 4443 [Scoi2015]小凸玩矩阵 网络流,二分
		[Scoi2015]小凸玩矩阵 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1564 Solved: 734[Submit][Status][Di ... 
- BZOJ4446 [Scoi2015]小凸玩密室  【树形Dp】
		题目 小凸和小方相约玩密室逃脱,这个密室是一棵有n个节点的完全二叉树,每个节点有一个灯泡.点亮所有灯 泡即可逃出密室.每个灯泡有个权值Ai,每条边也有个权值bi.点亮第1个灯泡不需要花费,之后每点亮4 ... 
- [bzoj4446] [loj#2009] [Scoi2015] 小凸玩密室
		Description 小凸和小方相约玩密室逃脱,这个密室是一棵有 \(n\) 个节点的完全二叉树,每个节点有一个灯泡.点亮所有灯泡即可逃出密室.每个灯泡有个权值 \(Ai\) ,每条边也有个权值 \ ... 
随机推荐
- QVector的内存分配策略
			我们都知道 STL std::vector 作为动态数组在所分配的内存被填满时.假设继续加入数据,std::vector 会另外申请一个大小当前容量两倍的区域(假设 n > size 则申请 n ... 
- binary-tree-postorder-traversal——二叉树后续遍历
			Given a binary tree, return the postorder traversal of its nodes' values. For example:Given binary t ... 
- TagCanvas - HTML5 Canvas Tag Cloud
			http://www.goat1000.com/tagcanvas.php watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbmlja3JvcHJhaw==/ ... 
- zoj1232Adventure of Super Mario(图上dp)
			题目连接: 啊哈哈.点我点我 思路: 这个题目是一个图上dp问题.先floyd预处理出图上全部点的最短路,可是在floyd的时候,把可以用神器的地方预处理出来,也就是转折点地方不能为城堡..预处理完成 ... 
- 【bzoj3175】[Tjoi2013]攻击装置
			每两个能互相攻击且能放置的点连一条双向边,然后跑二分图最大点独立集即可 #include<algorithm> #include<iostream> #include<c ... 
- C标准库中atoi的一种可能的实现
			为避免与标准库中的atoi产生歧义, 我将自己编写的函数命名为strToInt, 以下是示例代码 #include <stdio.h> int strToInt(const char *s ... 
- kaminari分页插件样式
			修改国际化文件,zh-cn views: pagination: first: "首页" last: "尾页" previous: "上一页" ... 
- redis03----link 链表操作
			link 链表结构 之前是操作字符串string 链表:头元素,后面一个一个的指向后面的元素.Redis内部实现了链表的结构.链表的头尾,从一个元素找到另外的元素. 链表的名字也是一个key. flu ... 
- Android ViewDragHelper及移动处理总结
			概述 2013年谷歌i/o大会上介绍了两个新的layout: SlidingPaneLayout和DrawerLayout,现在这俩个类被广泛的运用.我们知道在我们实际的开发中往往会涉及到很多的拖动效 ... 
- hdu 1963 Investment  解题报告
			题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1963 题目意思:有 本金 money,还有一些股票的种类,第 i 种股票买入需要 value[i] 这 ... 
