首页 技术 正文
技术 2022年11月21日
0 收藏 806 点赞 3,071 浏览 1947 个字

题面

解题思路

搞了三个多小时。。。。

noip时的数据很水,直接暴力n^3过。

我们考虑优化,首先可以贪心,我们要在直径上选肯定越插长越好,所以n^2其实就可以解决。但这还不够,根据直径的最长性,我们可以用一个单调队列优化。

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>using namespace std;
const int MAXN = 500005;
const int inf = 0x7fffffff;inline int rd(){
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-1;ch=getchar();}
while(isdigit(ch)) {x=(x<<1)+(x<<3)+ch-48;ch=getchar();}
return x*f;
}int n,s,num,a[MAXN],father[MAXN];
int head[MAXN],cnt,D,top[MAXN],d[MAXN];
int to[MAXN<<1],nxt[MAXN<<1],val[MAXN<<1];
int ans=inf,dis[MAXN],diameter,mx,st,last;
bool vis[MAXN];inline void add(int bg,int ed,int v){
to[++cnt]=ed,val[cnt]=v,nxt[cnt]=head[bg],head[bg]=cnt;
}inline void dfs1(int x,int fa){
for(register int i=head[x];i;i=nxt[i]){
int u=to[i];
if(u==fa) continue;
dis[u]=max(dis[u],dis[x]+val[i]);
if(dis[u]>mx){
mx=dis[u];
st=u;
}
dfs1(u,x);
}
}inline void dfs2(int x,int fa){
for(register int i=head[x];i;i=nxt[i]){
int u=to[i];
if(u==fa) continue;
father[u]=x;
dis[u]=max(dis[u],dis[x]+val[i]);
if(dis[u]>diameter){
diameter=dis[u];
last=u;
}
dfs2(u,x);
}
}inline void dfs4(int rt,int x,int DIS){
for(register int i=head[x];i;i=nxt[i]){
int u=to[i];
if(vis[u]) continue;
vis[u]=1;
if(DIS+val[i]>d[rt])
d[rt]=DIS+val[i];
dfs4(rt,u,DIS+val[i]);
vis[u]=0;
}
}int main(){
n=rd();s=rd();
for(register int i=1;i<n;i++){
int x=rd(),y=rd(),z=rd();
add(x,y,z);add(y,x,z);
}
dfs1(1,0);
for(register int i=1;i<=n;i++) dis[i]=0;
dfs2(st,0);
// cout<<diameter<<endl;
D=diameter;
mx=0;
for(register int i=last;i;i=father[i]) {
top[++num]=i;vis[i]=1;
a[i]=dis[last]-dis[i];
// cout<<a[i]<<endl;
}
// for(register int i=1;i<=num;i++) cout<<a[i]<<endl;
for(register int i=1;i<=num;i++) dfs4(top[i],top[i],0),mx=max(mx,d[top[i]]);
// for(register int i=1;i<=num;i++) cout<<top[i]<<" "<<a[top[i]]<<endl;;
// ans=max(d[top[1]],max(a[top[1]],a[top[num]]-a[top[1]]));
int l=1;
for(register int i=1;i<=num;i++){
if(l==num) break;
while(a[top[l+1]]-a[top[i]]<=s && l<num) l++;
int now=max(mx,max(a[top[i]],a[top[num]]-a[top[l]]));
ans=min(ans,now);
}
printf("%d",ans);
return 0;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,997
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,511
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,356
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,139
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,770
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,848