[题解]luogu_P3304直径(直径必经边
时间:2019-10-15
本文章向大家介绍[题解]luogu_P3304直径(直径必经边,主要包括[题解]luogu_P3304直径(直径必经边使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
这题做法好多好多啊
首先我们发现直径的重合部分一定是类似于
这样的
然后考虑产生多条直径的条件,一定是某点走到底和它走到直径的一端长度相同
这里的每条线其实可以看做每个点子树最深的地方了,那么我们处理出直径上每个点最深能到达的地方,扫一遍,找到两个端点,这两个端点之间就是必经边了
dis数组用的比较乱,但是是对的
#include<bits/stdc++.h> using namespace std; const int maxn=200009; int n; struct node{ int v,nxt,w; }e[maxn<<1]; int head[maxn],cnt; inline void add(int u,int v,int w){ e[++cnt].v=v;e[cnt].w=w;e[cnt].nxt=head[u];head[u]=cnt; } int fa[maxn],far; long long dis[maxn]; bool dia[maxn]; void dfs(int x,int f){ fa[x]=f; if(dis[x]>dis[far])far=x; for(int i=head[x];i;i=e[i].nxt){ int y=e[i].v; if(y==f||dia[y])continue; dis[y]=dis[x]+e[i].w; dfs(y,x); } } int main(){ scanf("%d",&n); for(int i=1,u,v,w;i<n;i++){ scanf("%d%d%d",&u,&v,&w); add(u,v,w);add(v,u,w); } dfs(1,0);int l=far; dis[far]=0;dfs(far,0); printf("%lld\n",dis[far]); int r=far; for(int i=r;i;i=fa[i])dia[i]=1; bool flg=0; int ll=l,rr=r; for(int i=fa[rr];i!=ll;i=fa[i]){ int ld=dis[i],rd=dis[rr]-dis[i];//到左右端点距离 dis[i]=0;far=i; dfs(i,fa[i]); if(dis[far]==rd)r=i;//子树深度和右端点距离相同,有其他直径 if(dis[far]==ld&&!flg)flg=1,l=i;//第一次最优 } int ans=1; for(int i=fa[r];i!=l;i=fa[i])ans++; printf("%d\n",ans); }
原文地址:https://www.cnblogs.com/superminivan/p/11678213.html
- NGS基础 - FASTQ格式解释和质量评估
- 数据结构之串
- 生信宝典之傻瓜式 (一) 如何提取指定位置的基因组序列
- 注意map<> 的[]
- 生信宝典之傻瓜式 (二) 如何快速查找指定基因的调控网络
- React Native组件只Image
- 数据结构之线性表
- 生信宝典之傻瓜式 (三) 我的基因在哪里发光 - 如何查找基因在发表研究中的表达
- 谈谈 char *num="123";和char num[4]="123";的区别
- 未越狱的iPhone/iPad也中招:走近强大的间谍软件XAgent与MadCap
- 【年末收藏】17个新手常见Python运行时错误
- C++ STL之priority_queue
- 链表的相关操作
- 《笨办法学Python》 第0课手记
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 千万级数据表选错索引导致的线上慢查询事故
- 递归优化
- Webshell 高级样本收集
- 处理Sprint Boot与Storm1.2.2日志实现的冲突,使用logback记录日志
- Docker 命令总结
- python主题LDA建模和t-SNE可视化
- cannot import name ‘imresize‘ from ‘scipy.misc‘
- 一分钟基础:计算机为什么使用二进制?
- 使用hibernate validate做参数校验
- Leetcode No.4 寻找两个正序数组的中位数
- R语言 RevoScaleR的大规模数据集决策树模型应用案例
- 快速学习-sentinel控制台
- 快速学习-sentinel注解支持
- Java工具集-验证码工具类
- RocketMQ 零基础 集群及控制台部署