BZOJ2282: [Sdoi2011]消防

时间:2021-08-07 07:32:58

题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2282

答案一定是在直径上的一段,然后答案一定不会小于不在直径上的点到直径的距离(要是可以的话那当前这条直径就不是直径了)

然后二分一遍,当前段的最长答案只可能在s->l,r->t取到,其他都是取不到的所以判断这两个就可以了。

#include<cstring>
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<set>
#define rep(i,l,r) for (int i=l;i<=r;i++)
#define down(i,l,r) for (int i=l;i>=r;i--)
#define clr(x,y) memset(x,y,sizeof(x))
#define maxn 300500
#define inf int(1e9)
#define mm 1000000007
typedef long long ll;
using namespace std;
struct data{int obj,pre;ll c;
}e[maxn*];
int dis[maxn],num[maxn],D,l,r,mid,S;
int n,tot,cnt,s,t,st[maxn],head[maxn],fa[maxn],mark[maxn];
int read(){
int x=,f=; char ch=getchar();
while (!isdigit(ch)){if (ch=='-') f=-; ch=getchar();}
while (isdigit(ch)){x=x*+ch-''; ch=getchar();}
return x*f;
}
void insert(int x,int y,int z){
e[++tot].obj=y; e[tot].pre=head[x]; e[tot].c=z; head[x]=tot;
}
void bfs(int s){
rep(i,,n) dis[i]=-; dis[s]=;
queue<int> q; q.push(s);
while (!q.empty()){
int u=q.front(); q.pop();
for (int j=head[u];j;j=e[j].pre){
int v=e[j].obj;
if (dis[v]==-) {
fa[v]=u;
if (!mark[v]) dis[v]=dis[u]+e[j].c; else dis[v]=dis[u];
q.push(v);
}
}
}
}
bool jud(int D){
int l=,r=cnt;
while (l<cnt&&num[]-num[l+]<=D) l++;
while (r>&&num[r-]<=D) r--;
return num[l]-num[r]<=S;
}
int main(){
// freopen("in.txt","r",stdin);
n=read(); S=read();
rep(i,,n-){
int x=read(),y=read(); int z=read();
insert(x,y,z); insert(y,x,z);
}
bfs(); rep(i,,n) if (dis[i]>dis[s]) s=i;
bfs(s); rep(i,,n) if (dis[i]>dis[t]) t=i;
D=dis[t];
int now=t; st[++cnt]=t; num[cnt]=dis[t];
while (now!=s){
now=fa[now]; mark[now]=;
st[++cnt]=now;
num[cnt]=dis[now];
}
bfs(s);
rep(i,,n) l=max(l,dis[i]); r=D;
if (S<D){
while (l<=r){
ll mid=(l+r)/;
if (jud(mid)) r=mid-;
else l=mid+;
}
}
printf("%d\n",l);
return ;
}

BZOJ2282: [Sdoi2011]消防的更多相关文章

  1. BZOJ2282 SDOI2011消防&sol;NOIP2007树网的核(二分答案&plus;树形dp)

    要求最大值最小容易想到二分答案.首先对每个点求出子树中与其最远的距离是多少,二分答案后就可以标记上一些必须在所选择路径中的点,并且这些点是不应存在祖先关系的.那么如果剩下的点数量>=3,显然该答 ...

  2. NOIP2007 树网的核 &amp&semi;&amp&semi; &lbrack;BZOJ2282&rsqb;&lbrack;Sdoi2011&rsqb;消防

    NOIP2007 树网的核 树的直径的最长性是一个很有用的概念,可能对一些题都帮助. 树的直径给定一棵树,树中每条边都有一个权值,树中两点之间的距离定义为连接两点的路径边权之和.树中最远的两个节点之间 ...

  3. 【BZOJ2282】&lbrack;Sdoi2011&rsqb;消防 树形DP&plus;双指针法&plus;单调队列

    [BZOJ2282][Sdoi2011]消防 Description 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这 ...

  4. &lbrack;洛谷P2491&rsqb; &lbrack;SDOI2011&rsqb;消防

    洛谷题目链接:[SDOI2011]消防 题目描述 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这个国家的人对火焰有超 ...

  5. &lbrack;SDOI2011&rsqb;消防(树的直径)

    [SDOI2011]消防 题目描述 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这个国家的人对火焰有超越宇宙的热情, ...

  6. Bzoj 2282&colon; &lbrack;Sdoi2011&rsqb;消防&lpar;二分答案&rpar;

    2282: [Sdoi2011]消防 Time Limit: 10 Sec Memory Limit: 512 MB Description 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条 ...

  7. &lbrack;SDOI2011&rsqb;消防(贪心,图论,树的直径)

    [SDOI2011]消防 题目描述 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这个国家的人对火焰有超越宇宙的热情, ...

  8. BZOJ1999或洛谷1099&amp&semi;BZOJ2282或洛谷2491 树网的核&amp&semi;&lbrack;SDOI2011&rsqb;消防

    一道树的直径 树网的核 BZOJ原题链接 树网的核 洛谷原题链接 消防 BZOJ原题链接 消防 洛谷原题链接 一份代码四倍经验,爽 显然要先随便找一条直径,然后直接枚举核的两个端点,对每一次枚举的核遍 ...

  9. 【bzoj2282】&lbrack;Sdoi2011&rsqb;消防

    两次bfs可得直径,答案一定不会小于所有点到直径的距离最大值,只要把直径上的边权设为0,任选直径上一点bfs可得将最大值作为二分下界,二分直径左右端点的舍弃部分 #include<algorit ...

随机推荐

  1. HDU 5936 Difference

    题意: 有一个函数f(y, k) = y的每个十进制位上的数字的k次幂之和 给x, k 求 有多少个y满足 x = f(y, k) - y 思路: (据说这叫中途相遇法?) 由于 x >= 0 ...

  2. &lbrack;Python&rsqb; Removing a non-empty folder

    Removing a non-empty folder You will get an ‘access is denied’ error when you attempt to use os.remo ...

  3. C&num;事件与接口

    using System; namespace ConsoleApplication1d { delegate void MsgDel(string s); interface IMsg { even ...

  4. Mysql varchar大小长度问题介绍

    如果被 varchar 超过上述的 b 规则,被强转成 text 类型,则每个字段占用定义长度为 11 字节,当然这已经不是 varchar 了4.0版本以下,varchar(20),指的是20字节, ...

  5. 排队(BZOJ1731:&lbrack;Usaco2005 dec&rsqb;Layout 排队布局)

    [问题描述] Czy喜欢将他的妹子们排成一队.假设他拥有N只妹纸,编号为1至N.Czy让他们站成一行,等待自己来派送营养餐.这些妹纸按照编号大小排列,并且由于它们都很想早点吃饭,于是就很可能出现多只妹 ...

  6. 嵌入式C语言头文件的建立与使用

    如何正确编写 C 语言头文件和与之相关联的 c 源程序文件,这首先就要了解它们的各自功能. 要理解 C 文件与头文件(即.h)有什么不同之处,首先需要弄明白编译器的工作过程. 一般说来编译器会做以下几 ...

  7. C语言循环剖析(转载)

    一.if.else float变量与“零值”进行比较: float fTestVal = 0.0; if((fTestVal >= -EPSINON) && (fTestVal ...

  8. python self

    Python要self的理由 Python的类的方法和普通的函数有一个很明显的区别,在类的方法必须有个额外的第一个参数(self),但在调用这个方法的时候不必为这个参数赋值(显胜于隐的引发). Pyt ...

  9. 2018-2019-2-20175225 实验一 《Java开发环境的熟悉》实验报告

    2018-2019-2-20175225 实验一 <Java开发环境的熟悉>实验报告 一.实验内容及知识点 实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用IDEA编辑.编 ...

  10. linux分享三:文件操作

    查找文件命令: which       查看可执行文件的位置 whereis    查看文件的位置 locate       配 合数据库查看文件位置 find          实际搜寻硬盘查询文件 ...