P4103 [HEOI2014]大工程

 

P4103 [HEOI2014]大工程

题目描述

详见:P4103 [HEOI2014]大工程

Solution

显然是虚树的板子题啊(我也不造我为啥调了1h)

直接建虚树,DP。

两两路径和很好求,只要考虑每条边的贡献,设k为询问的关键点个数,size[x]   为子树x中的关键点数量。

ans+=(k-size[son[x]])*size[son[x]]*dis(x,son[x])

对于最大最小路径,

设  mx[i]  为以i为根的子树中距离i最远的点的距离, mn[i]   为以i为根的子树中距离i最近的点的距离。

mx[x]=max(mx[x],mx[son[x]]+dis(x,son[x]))

mn[x]=min(mn[x],mn[son[x]]+dis(x,son[x]))

maxans=max(maxans,mx[x]+mx[son[x]]+dis(x,son[x]))

minans=min(minans,mn[x]+mn[son[x]]+dis(x,son[x]))

然后就没有然后了。

Code

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MAXN=3e6+50;
const int INF=0x3f3f3f3f;
bool Flag[MAXN];
ll ans1;
int dis[MAXN],ans2,ans3,k,DFN=0,Log[MAXN],a[MAXN];
int stk[MAXN],mn[MAXN],mx[MAXN],size[MAXN],fa[MAXN][21],dep[MAXN],dfn[MAXN],top;
vector<int> e[MAXN],son[MAXN];inline int read()
{int x=0,f=1; char c=getchar();while (c<'0'||c>'9') { if(c=='-') f=-1; c=getchar(); }while (c>='0'&&c<='9') { x=(x<<3)+(x<<1)+(c^48); c=getchar(); }return x*f;
}
void add_edge(int u,int v){ son[u].push_back(v); }
void tree_dp(int x,int father)
{//cout<<x<<" "<<father<<endl;for (int i=0;i<son[x].size();i++) if (son[x][i]!=father) tree_dp(son[x][i],x);mx[x]=Flag[x]?0:-INF,mn[x]=Flag[x]?0:INF,size[x]=Flag[x];for (int i=0;i<son[x].size();i++)if (son[x][i]!=father) {int len=(dep[son[x][i]]-dep[x]);ans1+=1ll*size[son[x][i]]*(k-size[son[x][i]])*len;if (size[x]>0){ans2=max(ans2,mx[x]+mx[son[x][i]]+len); ans3=min(ans3,mn[x]+mn[son[x][i]]+len); }mx[x]=max(mx[x],mx[son[x][i]]+len);mn[x]=min(mn[x],mn[son[x][i]]+len);size[x]+=size[son[x][i]];}Flag[x]=0;son[x].clear();
}
int get_lca(int x,int y)
{if (dep[x]<dep[y]) swap(x,y);for (int i=Log[dep[x]];i>=0;i--)if (dep[fa[x][i]]>=dep[y]) x=fa[x][i];if (x==y) return x;for (int i=Log[dep[x]];i>=0;i--)if (fa[x][i]!=fa[y][i]) x=fa[x][i],y=fa[y][i];return fa[x][0];
}
void insert(int x)
{if (top==1) { stk[++top]=x; return; }int lca=get_lca(stk[top],x);if (lca==stk[top]) { stk[++top]=x; return; }while (top>1&&dfn[stk[top-1]]>=dfn[lca]) add_edge(stk[top-1],stk[top]),top--;if (stk[top]!=lca) add_edge(lca,stk[top]),stk[top]=lca;stk[++top]=x; 
}
void dfs(int x,int father)
{dep[x]=dep[father]+1;fa[x][0]=father;dfn[x]=++DFN;for (int i=1;i<=Log[dep[x]];i++) fa[x][i]=fa[fa[x][i-1]][i-1];for (int i=0;i<e[x].size();i++) if (e[x][i]!=father) dfs(e[x][i],x);
}
int compare(int x,int y){return dfn[x]<dfn[y]; }
int main()
{int n=read();for (int i=1;i<n;i++) {int u=read(),v=read();e[u].push_back(v);e[v].push_back(u);}dep[0]=-1,Log[1]=0;for (int i=2;i<=n;i++) Log[i]=Log[i>>1]+1;dfs(1,0);int Case=read();while (Case--){ans1=0,ans2=0,ans3=INF;k=read();for (int i=1;i<=k;i++) a[i]=read();sort(a+1,a+k+1,compare);stk[top=1]=1,size[1]=1; for (int i=1;i<=k;i++) {Flag[a[i]]=1;if (a[i]!=1) insert(a[i]),size[a[i]]=1;}while (top>1) add_edge(stk[top-1],stk[top]),top--;tree_dp(1,0);printf("%lld %d %d\n",ans1,ans3,ans2);}return 0;
}

代码缩进又被搞了……

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315828.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【中部武汉】理想离家并不遥远

▼我叫Mike, 是一名“高端”程序猿。毕业于武汉某男生比例占据 70%的高校。我的家乡是湖北襄阳&#xff0c;一个历史悠久的文化名城。7年前&#xff0c;我还是一个刚毕业的毛头小子&#xff0c;在学校也算是半个风云人物&#xff0c;年轻气盛&#xff0c;心比天高&#xff0c;放…

P2495 [SDOI2011]消耗战

P2495 [SDOI2011]消耗战 题目描述 详见&#xff1a;P2495 [SDOI2011]消耗战 Solution 此题是虚树的经典版子题吧qwq。 是不是直接贴代码就行了啊&#xff08;反正不是luogu题解&#xff0c;没有人查&#xff09;。 大概就是先建出虚树&#xff08;一般给定一堆关键点的题…

使用Try.NET创建可交互.NET文档

原文地址&#xff1a;Create Interactive .NET Documentation with Try .NET[1] 原文作者&#xff1a;Maria 译文地址&#xff1a;https://www.cnblogs.com/lwqlun/p/10894497.html 译者&#xff1a;Lamond Lu背景当我们编写开发人员使用的文档时&#xff0c;我们需要捕捉他们的…

Link-Cut Tree

Link-Cut Tree 概述. LCT是一种支持动态维护树上路径信息的数据结构&#xff0c;其本质是实链剖分&#xff0c;通过其他数据结构维护实链的信息达到维护路径及一些子树信息的效果&#xff08;通常为splay&#xff09; 刚开始学的时候感觉很难&#xff0c;但做过几道题了解套…

ASP.NET Core模块化前后端分离快速开发框架介绍

源码地址GitHub&#xff1a;https://github.com/iamoldli/NetModular演示地址地址&#xff1a;http://118.24.75.170:6220/账户&#xff1a;admin密码&#xff1a;admin前端框架演示地址(临时)地址&#xff1a;http://progqx5cu.bkt.clouddn.com/skins/index.html#/账户&#x…

[POJ2888] Magic Bracelet

[POJ2888] Magic Bracelet 题目描述 简要题意&#xff1a;给圆上个点染色&#xff0c;颜色有种&#xff0c;其中对颜色不能相邻&#xff0c;循环同构&#xff0c;多组数据&#xff0c;询问染色方案数。 Solution 大概就是一道挺显然的Burnside题&#xff08;一般染色&#x…

使用命令行导出 SQL Server 数据层应用程序

点击上方蓝字关注“汪宇杰博客”我们可以使用 SSMS 导出 SQL Server 数据库的数据层应用程序。我在本地机器上使用这种方法已经有好几年了。如果不知道什么是 DAC&#xff0c;您可以参考 Microsoft 文档&#xff1a;https://docs.microsoft.com/en-us/sql/relational-databases…

Codeforces 1065 E. Side Transmutations

Codeforces 1065 E. Side Transmutations 题目描述 题意&#xff1a;一个字符串长度为&#xff0c;字符集大小为 &#xff0c;再给出种交换方式&#xff0c;表示可以交换。如果两个不同的串能够通过任意的交换方式得到相同的串&#xff0c;则视为相同&#xff0c;求方案数。…

P1 用reactjs和bootstrap创建页面IDE

文章目录页面IDE展示&#xff1a;要求&#xff1a;安装好Node.jsreactjs组件化开发页面IDE展示&#xff1a; 要求&#xff1a; 希望能够达到eclipse辅助编程的功能 关键字提醒&#xff0c;高亮 1&#xff0c; 有类似C语言的语法结构 2&#xff0c; 支持变量绑定 3&#xff0c;…

所以Apache基金会不受美国法律约束?

开源中国昨天发布的一篇文章《开源界也要注意&#xff0c;Apache 基金会与 GitHub 都受美国法律约束》引发了开源届乃至整个 IT 行业的热烈讨论&#xff0c;其中有个别声音认为文章的说法有误&#xff0c;甚至制造了恐慌。文中我们引用了两处内容&#xff0c;分别是 Apache 软件…

C#中的Explicit和Implicit了解一下吧

今天在研究公司项目框架的时候看到了下面的用法&#xff0c;public static implicit operator JsonData(int data);。貌似很久没用过这种隐式转换的写法了&#xff0c;因此重新温习一下C#中转换相关的知识。作者&#xff1a;依乐祝原文地址&#xff1a;https://www.cnblogs.com…

Dapper的正确使用姿势

本文demo适用于MySQL优点高性能、易排查、易运维、灵活可控缺点和EF相比&#xff0c;手写sql当修改表结构不易发现bug。习惯了EF后再来使用Dapper&#xff0c;会很难适应那种没有了强类型的安全感。不过可以用单元测和心细来避免。问题&#xff1a;IDbConnection需不需要手动Op…

[NewLife.XCode]百亿级性能

NewLife.XCode是一个有10多年历史的开源数据中间件&#xff0c;支持nfx/netcore&#xff0c;由新生命团队(2002~2019)开发完成并维护至今&#xff0c;以下简称XCode。整个系列教程会大量结合示例代码和运行日志来进行深入分析&#xff0c;蕴含多年开发经验于其中&#xff0c;代…

Web API 速率限制(一)

导读当您API有大量消费者或者请求量猛增到影响程序可用性的时候&#xff0c;您可能需要对API进行速率限制。所以对API进行限速的在于&#xff1a;在增加可靠性和可用性的同时来保护基础架构&#xff0c;你不希望某个恶意的API消费者或者差劲的API客户端开发者通过Dos攻击把你的…

构建简单的微服务架构

前言 本篇仅作引导&#xff0c;内容较多&#xff0c;如果阅读不方便&#xff0c;可以使用电脑打开我们的文档官网进行阅读。如下图所示&#xff1a;文档官网地址&#xff1a;docs.xin-lai.com目录总体介绍微服务架构的好处 微服务架构的不足&#xff08;这个时候…

读《代码整洁之道》

什么是整洁代码代码的质量非常重要&#xff0c;糟糕的代码有可能会毁了一个公司。对于一个很注重代码质量的人来说呆在一个只关注交付而不关注代码质量的公司是很痛苦的。什么是整洁的代码&#xff0c;不同的人又不同的定义。我认为整洁的代码应该是符合所使用语言代码规范的&a…

在 DotNetty 中实现同步请求

一、背景DotNetty 本身是一个优秀的网络通讯框架&#xff0c;不过它是基于异步事件驱动来处理另一端的响应&#xff0c;需要在单独的 Handler 去处理相应的返回结果。而在我们的实际使用当中&#xff0c;尤其是 客户端程序 基本都是 请求-响应 模型&#xff0c;在发送了数据时候…

ASP.NET Core 中间件

1.前言中间件&#xff08;middleware&#xff09;是一种装配到应用管道以处理请求和响应的组件。每个组件&#xff1a;●可选择是否将请求传递到管道中的下一个组件。●可在管道中的下一个组件前后执行工作。请求委托&#xff08;request delegates&#xff09;用于建立请求管道…

.Net Core实现的文档数据库RavenDb

说到文档数据库&#xff0c;大家能想到很多&#xff0c;MongoDb,coudDb。如果只是文档的话&#xff0c;甚至可以使用对象存储&#xff0c;阿里的oss&#xff0c;腾讯cos。但是这里小编选择这RavenDb&#xff0c;原因是对象存储下行太贵了(来自穷逼的绝望)。MongoDb据说非常占用…

Web Template Studio 发布!在 VS Code 中轻松创建 Web 应用

作为一个 Web 应用开发者&#xff0c;Scaffolding Tool&#xff08;脚手架工具&#xff09;一定是在创建项目时的重要工具。许多开发者会习惯于使用基于 CLI 的脚手架工具来创建 Web 应用&#xff0c;也有许多开发者喜欢使用类似于 VS IDE 的基于 UI 的 Wizard 向导。近期&…