Building Fire Stations 39届亚洲赛牡丹江站B题
题意:
给你一棵树,让你再里面选取两个点作为**点,然后所有点的权值是到这两个点中最近的那个的距离,最后问距离中最长的最短是多少,输出距离还有那两个点(spj特判)。
思路:
现场赛的时候我们压根就没看这道题,还有k题也是水题,可惜当时我们读的题意不对<以为数字可以随意断开,然后拼接的数组可以再段。。>,最后只过了3个题,拿了个铜,不过没啥遗憾,因为这是第一次去亚洲赛,没空手而归就是好事,下几场放开了打就行了。
回到这个题目,其实这个题目我们可以判定的是这两个点分别"罩着"两棵树<原因是最后的答案已经是小于等于树的直径的一半的,如果在同一侧,那么答案就大于等于直径的一半了>,这两颗树一定是整个树从直径断开的分成的两颗树,那么我们就两遍广搜分成两颗树,然后再在两颗树上分别找直径,然后两个点就是直径的中点,然后答案就是两个塔到所有自己所在的那颗子树上所有点的最大距离的最大距离,其他的还有一些细节,比如分成两颗树后有一棵树只剩1个点的时候,去中点可能弄错,这个地方注意点,具体细节可以看代码。
#include<stdio.h>
#include<string.h>
#include<queue> #define N_node 200000 + 10
#define N_edge 400000 + 20 using namespace std; typedef struct
{
int node ,t;
}NODE; typedef struct
{
int to ,next;
}STAR; NODE xin ,tou;
STAR E[N_edge];
int list[N_node] ,tot;
int mer[N_node] ,mark[N_node];
int root[N_node]; void add(int a ,int b)
{
E[++tot].to = b;
E[tot].next = list[a];
list[a] = tot;
E[++tot].to = a;
E[tot].next = list[b];
list[b] = tot;
} int maxx ,mknode;
void BFS(int s ,int aa ,int bb)
{
queue<NODE>q;
memset(mark ,0 ,sizeof(mark));
xin.node = s ,xin.t = 0;
mark[s] = 1;
q.push(xin);
maxx = 0 ,mknode = s;
while(!q.empty())
{
tou = q.front();
q.pop();
if(maxx < tou.t)
{
maxx = tou.t;
mknode = tou.node;
}
for(int k = list[tou.node] ;k ;k = E[k].next)
if(!mark[E[k].to])
{
xin.node = E[k].to;
xin.t = tou.t + 1;
if(aa == tou.node && bb == xin.node || aa == xin.node && bb == tou.node)
continue;
mer[xin.node] = tou.node;
mark[E[k].to] = 1;
q.push(xin);
}
}
} int main ()
{
int n ,t ,i ,a ,b;
scanf("%d" ,&t);
while(t--)
{
scanf("%d" ,&n);
memset(list ,0 ,sizeof(list)) ,tot = 1;
for(i = 1 ;i < n ;i ++)
{
scanf("%d %d" ,&a ,&b);
add(a ,b);
} BFS(1 ,-1 ,-1);
int mk1 = mknode;
BFS(mk1 ,-1 ,-1);
int mk2 = mknode;
int nowid = 0;
int x = mk2;
while(x != mk1)
{
root[++nowid] = x;
x = mer[x];
} root[++nowid] = mk1; int aa = root[nowid/2];
int bb = root[nowid/2+1]; BFS(aa ,aa ,bb);
mk1 = mknode;
BFS(mk1 ,aa ,bb);
mk2 = mknode;
nowid = 0;
x = mk2;
while(x != mk1)
{
root[++nowid] = x;
x = mer[x];
}
root[++nowid] = mk1; //for(i = 1 ;i <= nowid ;i ++)
//printf("%d *\n" ,root[i]);
//puts(""); int aaa = root[nowid/2+1]; BFS(bb ,aa ,bb);
mk1 = mknode;
BFS(mk1 ,aa ,bb);
mk2 = mknode;
nowid = 0;
x = mk2;
while(x != mk1)
{
root[++nowid] = x;
x = mer[x];
}
root[++nowid] = mk1;
int bbb = root[nowid/2+1]; BFS(aaa ,aa ,bb);
int Ans1 = maxx;
BFS(bbb ,aa ,bb);
int Ans2 = maxx;
int Ans = Ans1 > Ans2 ? Ans1 : Ans2;
printf("%d %d %d\n" ,Ans ,aaa ,bbb);
}
return 0;
}
Building Fire Stations 39届亚洲赛牡丹江站B题的更多相关文章
- Known Notation 39届亚洲赛牡丹江站K题
题意: 题意,哎!说道题意就蛋疼啊,比赛的时候就愣是把这个题目读成数字可以随意组合,比如123 可以拆成1 23 ,12 3 ,1 2 3,结果显然,水题当神题,各种想不出来,然后就显然的 ...
- Average Score39届亚洲赛牡丹江站A题
题意: A班有n个人,B班有m个人,然后现在给你n-1个A班人的成绩,和m个B班人的成绩,然后题目要求求出A班剩下的没给成绩那个人的成绩范围,要求是这个人从A班转到B班后能使A,B的平均分 ...
- zoj 3820 Building Fire Stations 树的中心
Building Fire Stations Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.zju.edu.cn/onlinejudge ...
- ZOJ Problem Set - 3820 Building Fire Stations 【树的直径 + 操作 】
题目:problemId=5374" target="_blank">ZOJ Problem Set - 3820 Building Fire Stations 题 ...
- zoj 3820 Building Fire Stations (二分+树的直径)
Building Fire Stations Time Limit: 5 Seconds Memory Limit: 131072 KB Special Judge Marjar ...
- zoj 3820 Building Fire Stations(二分法+bfs)
题目链接:zoj 3820 Building Fire Stations 题目大意:给定一棵树.选取两个建立加油站,问说全部点距离加油站距离的最大值的最小值是多少,而且随意输出一种建立加油站的方式. ...
- 2014ACM/ICPC亚洲区域赛牡丹江站现场赛-A ( ZOJ 3819 ) Average Score
Average Score Time Limit: 2 Seconds Memory Limit: 65536 KB Bob is a freshman in Marjar Universi ...
- zoj 3822 Domination 概率dp 2014牡丹江站D题
Domination Time Limit: 8 Seconds Memory Limit: 131072 KB Special Judge Edward is the headm ...
- 2014ACM/ICPC亚洲区域赛牡丹江站汇总
球队内线我也总水平,这所学校得到了前所未有的8地方,因为只有两个少年队.因此,我们13并且可以被分配到的地方,因为13和非常大的数目.据领队谁oj在之上a谁去让更多的冠军.我和tyh,sxk,doub ...
随机推荐
- postman接口测试之设置全局变量和设置环境变量和全局变量
一.概念 1.环境变量 就是接口的域名或IP地址. 2.全局变量 就是一个作用域为整个postman的变量. 二.使用场景 1.环境变量 在测试的过程中,经常会频繁切换环境,本地环境验证.发布到测试环 ...
- JavaScript offset、client、scroll家族
offsetParent <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...
- [LeetCode 279.] Perfect Squres
LeetCode 279. Perfect Squres DP 是笨办法中的高效办法,又是一道可以被好办法打败的 DP 题. 题目描述 Given a positive integer n, find ...
- 双向链表及有关操作(C语言)
#include <stdio.h> #include <stdlib.h> /** * 含头节点双向链表定义及有关操作 */ //操作函数用到的状态码 #define TRU ...
- 一文弄懂js的执行上下文与执行上下文栈
目录 执行上下文与执行上下文栈 变量提升与函数提升 变量提升 函数提升 变量提升与函数提升的优先级 变量提升的一道题目引出var关键字与let关键字各自的特性 执行上下文 全局执行上下文 函数(局部) ...
- C语言入门-ide的概念介绍及codeblocks编辑器安装汉化
大家好,本章教程就ide(集成开发环境)来说一说. ide就是编译器+编辑器,原理就是在编辑器写代码,然后编辑器会让编译器来编译成二进制可执行文件. 常见的c/c++编译器有mingw64,msvc, ...
- arcgis10.2 全套安装教程
一.安装LicenseManager 1.运行在licensemanager目录下的Setup.exe 2.安装完成后点击stop停止服务,然后点击"OK" 3.选择ArcGIS1 ...
- 《数据持久化与鸿蒙的分布式数据管理能力》直播课答疑和PPT分享
问:hi3861开发板支持分布式数据库吗? 目前,分布式数据库仅支持Java接口,因此Hi3861没有现成的API用于操作分布式数据库. 问:分布式数据管理包括搜索吗? 分布式数据管理包括融合搜索能力 ...
- Sql Server存储过程和游标的配合操作
本段代码主要为了记录存储过程以及游标的使用,防止以后自己忘记 知识点:1.存储过程书写 2.游标书写 3.游标循环更新记录 create proc saletargetas declare @ower ...
- Windows Server 2016不小心卸载了.NET Framwork4.6后服务器管理器等功能都不能用的解决方案
之前卸载IIS的时候手贱把.NET FrameWork 4.6给卸载了,下面有一个比较简单的恢复方法. 可以尝试一下通过cmd命令DISM启用.NET 4.6:1. 首先运行如下命令查看当前的功能安装 ...