神仙题!参考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;
}

最新文章

  1. jsoup获取文档类示例
  2. a标签 不触发 目标链接
  3. Hibernate SQL Dialect 方言
  4. Java的位运算符详解实例——与(&amp;)、非(~)、或(|)、异或(^)
  5. Python2.x与3​​.x版本区别
  6. 详细讲解 关于Linux静态库和动态库的分析
  7. 采用Flume实时采集和处理数据
  8. JS-1
  9. Linux特殊符号
  10. obtainFreshBeanFactory()源码探究
  11. 静态变量setter注入
  12. 利用OpenVPN实现局域网内多台机器共享上网
  13. 项目导入时报错:The import javax.servlet.http.HttpServletRequest cannot be resolved 解决方法
  14. C# if else 使物体在X轴循环移动
  15. 全网最详细的CentOS7里安装MySQL时出现No package mysql-server available错误的解决办法(图文详解)
  16. python与VScode
  17. Robot Framework 教程 (4) - 自定义Library
  18. 洛谷P2194HXY烧情侣
  19. @JVM中的几种垃圾收集算法
  20. [uwp]自定义Behavior之随意拖动

热门文章

  1. 2.6.2 用NPOI操作EXCEL--设置密码才可以修改单元格内容
  2. google protocol buffer的原理和使用(一)
  3. Nova虚拟机迁移
  4. 简明扼要谈Spring IOC的好处
  5. Yarn调度器负载模拟器——Yarn Scheduler Load Simulator (SLS)
  6. Linux主要命令
  7. Android开发之中的一个个简单的通讯录实现(源代码)
  8. 中断线程Interrupt()
  9. 直播:中国HBase技术社区第一届MeetUp
  10. Linux搭建lnmp环境