当前位置: 首页 > news >正文

5560.树的直径

蛮不错的一道题目,你要利用树的性质分析出,你只需要维护上一次的树的直径的两个端点就好了

#include<iostream>using namespace std;
using ll = long long;
using pii = pair<int,int>;
const int N = 6e5+10;
const int inf = 0x3f3f3f3f;
const int mod = 1e9+7;
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int lcm(int a,int b){return a*b/gcd(a,b);}
int qmi(int a,int b,int mod){int res=1;while(b){if(b&1)res=res*a%mod;b>>=1;a=a*a%mod;}return res;}int n,q,m;// int e[N],ne[N],w[N],h[N],idx;
// void add(int a,int b,int c){// e[idx] = b,ne[idx] = h[a],w[idx] = c,h[a] = idx++;
// }int dep[N];
int fa[N][22];int lca(int a,int b){if(dep[a]<dep[b])swap(a,b);for(int i=20;i>=0;--i)if(dep[fa[a][i]]>=dep[b])a = fa[a][i];if(a==b)return a;for(int i=20;i>=0;--i)if(fa[a][i]!=fa[b][i])a = fa[a][i],b =fa[b][i];return fa[a][0];}int dist(int a,int b){return dep[a]+dep[b]-2*dep[lca(a,b)];
}void solve()
{cin>>n;dep[2] = dep[3] = dep[4] = 2;dep[1] = 1;fa[1][0] = 0;fa[2][0] = fa[3][0] = fa[4][0] = 1;int tem = 4;int A = 2,B = 3;while(n--){int a;cin>>a;int b = ++tem,c = ++tem;fa[b][0] = a,fa[c][0] = a;dep[b] = dep[a]+1,dep[c] = dep[a]+1;for(int i=1;i<=20;i++)fa[b][i] = fa[fa[b][i-1]][i-1] ;for(int i=1;i<=20;i++)fa[c][i] = fa[fa[c][i-1]][i-1] ;int dista = dist(b,A),distb = dist(b,B);int dists = dist(A,B);//cout<<A<<" "<<B<<" "<<b<<" "<<dista<<" "<<distb<<" "<<dists<<"\n";if(dista<=dists&&distb<=dists){cout<<dists<<"\n";continue;}if(dista>dists&&dista>=distb){B=b;cout<<dista<<"\n";continue;}if(distb>dists){A=b;cout<<distb<<"\n";continue;}}}signed main()
{ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);int _;//cin>>_;_ = 1;while(_--)solve();return 0;
}

http://www.lryc.cn/news/333231.html

相关文章:

  • Decoupled Multimodal Distilling for Emotion Recognition 论文阅读
  • 【css】使用display:inline-block后,元素间存在4px的间隔
  • 代码执行漏洞
  • SQLServer2022安装
  • vue2 配置@指向src
  • 用友U9 存在PatchFile.asmx接口任意文件上传漏洞
  • 如何卸载干净 IDEA(图文讲解)
  • 自动化运维(十)Ansible 之进程管理模块
  • 【leetcode279】完全平方数,动态规划解法
  • Java 元素排序(数组、List 集合)
  • 使用vite创建一个react18项目
  • 子集(迭代)(leetcode 78)
  • 汽车疲劳测试试验平台技术要求(北重厂家)
  • Redis -- 缓存雪崩问题
  • 【ARM 嵌入式 C 文件操作系列 20 -- 文件删除函数 remove 详细介绍】
  • LeetCode刷题之31.下一个排列
  • 【RISC-V 指令集】RISC-V 向量V扩展指令集介绍(九)- 向量定点算术指令
  • 【Java网络编程】IP网络协议与TCP、UDP网络传输层协议
  • C# 分布式自增ID算法snowflake(雪花算法)
  • commonJS和esModule的应用
  • (十一)RabbitMQ及SpringAMQP
  • STM32 M3内核寄存器概念
  • SQL语句的编写
  • Lecture 1~3 About Filter
  • 配置vscode链接linux
  • 论文阅读——MVDiffusion
  • Linux中的网络命令深度解析与CentOS实践
  • nginx配置实例(反向代理)
  • Flutter 解决NestedScrollView与TabBar双列表滚动位置同步问题
  • 云计算存在的安全隐患