「NOI2003」逃学的小孩
传送门:>HERE<
题意:给出一棵树(带权),要从一个节点C先走到距离它近的一个节点B,再走到A,要求最坏情况下的总路程(即最长)。
解题思路:
乍一看,A,B,C都没给出,这怎么求?
不妨设距离C较近的点位A。
分析发现,无论怎样,A~B是一定要走的。那么如何能让树上任意两点间距离最大呢?不难发现A,B就是该树直径的两个端点。那么只要两遍BFS就好了。
那么如何让A~C的路程最长呢?注意到A到C相较A到B是较短的。所以好像不怎么好求……但是可以枚举——枚举每个点作为C到A和B的距离,求出较小的那个,并且打擂得到最大值。
Code
- /*By QiXingzhi*/
- #include <cstdio>
- #include <queue>
- #include <iostream>
- #include <string>
- #include <cstring>
- #include <algorithm>
- #define r read()
- #define Max(a,b) (((a)>(b)) ? (a) : (b))
- #define Min(a,b) (((a)<(b)) ? (a) : (b))
- using namespace std;
- typedef long long ll;
- #define int ll
- const int N = ;
- const int INF = ;
- inline int read(){
- int x = ; int w = ; register int c = getchar();
- while(c ^ '-' && (c < '' || c > '')) c = getchar();
- if(c == '-') w = -, c = getchar();
- while(c >= '' && c <= '') x = (x << ) +(x << ) + c - '', c = getchar();
- return x * w;
- }
- struct Edge{
- int to,cost;
- };
- int n,m,x,y,z,A,B,ans,ans2;
- int d[N], d2[N], vis[N];
- vector <Edge> G[N];
- queue <int> q;
- inline void AddEdge(int u, int v, int w){
- Edge e;
- e.to = v;
- e.cost = w;
- G[u].push_back(e);
- }
- inline void BFS(int s){
- while(!q.empty()) q.pop();
- q.push(s);
- d[s] = ;
- vis[s] = ;
- int cur,sz,v;
- while(!q.empty()){
- cur = q.front();
- q.pop();
- sz = G[cur].size();
- for(int i = ; i < sz; ++i){
- v = G[cur][i].to;
- if(!vis[v]){
- vis[v] = ;
- d[v] = d[cur] + G[cur][i].cost;
- q.push(v);
- }
- }
- }
- }
- inline void BFS2(int s){
- while(!q.empty()) q.pop();
- q.push(s);
- d2[s] = ;
- vis[s] = ;
- int cur,sz,v;
- while(!q.empty()){
- cur = q.front();
- q.pop();
- sz = G[cur].size();
- for(int i = ; i < sz; ++i){
- v = G[cur][i].to;
- if(!vis[v]){
- d2[v] = d2[cur] + G[cur][i].cost;
- vis[v] = ;
- q.push(v);
- }
- }
- }
- }
- main(){
- n = r, m = r;
- for(int i = ; i <= m; ++i){
- x = r, y = r, z = r;
- AddEdge(x, y, z);
- AddEdge(y, x, z);
- }
- BFS();
- int __max = -;
- for(int i = ; i <= n; ++i){
- if(d[i] > __max){
- __max = d[i];
- A = i;
- }
- }
- ans = __max;
- memset(vis,,sizeof(vis));
- BFS(A);
- __max = -;
- for(int i = ; i <= n; ++i){
- if(d[i] > __max){
- __max = d[i];
- B = i;
- }
- }
- ans = __max;
- memset(vis,,sizeof(vis));
- BFS2(B);
- for(int i = ; i <= n; ++i) ans2 = Max(ans2, Min(d[i], d2[i]));
- printf("%lld", ans+ans2);
- return ;
- }
「NOI2003」逃学的小孩的更多相关文章
- BZOJ 1509: [NOI2003]逃学的小孩( 树形dp )
树形dp求出某个点的最长3条链a,b,c(a>=b>=c), 然后以这个点为交点的最优解一定是a+2b+c.好像还有一种做法是求出树的直径然后乱搞... ----------------- ...
- 【BZOJ1509】[NOI2003]逃学的小孩 直径
[BZOJ1509][NOI2003]逃学的小孩 Description Input 第一行是两个整数N(3 N 200000)和M,分别表示居住点总数和街道总数.以下M行,每行给出一条街道的 ...
- [NOI2003]逃学的小孩(树的直径)
[NOI2003]逃学的小孩 题目描述 Chris家的电话铃响起了,里面传出了Chris的老师焦急的声音:"喂,是Chris的家长吗?你们的孩子又没来上课,不想参加考试了吗?"一听 ...
- 洛谷 P4408 逃学的小孩 解题报告
P4408 [NOI2003]逃学的小孩 题目描述 Chris家的电话铃响起了,里面传出了Chris的老师焦急的声音:"喂,是Chris的家长吗?你们的孩子又没来上课,不想参加考试了吗?&q ...
- BZOJ 1509[NOI 2003]逃学的小孩 树形dp
1509: [NOI2003]逃学的小孩 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 995 Solved: 505[Submit][Status][ ...
- NOI 2003 逃学的小孩 (树的直径)
[NOI2003 逃学的小孩] 题目描述 Chris家的电话铃响起了,里面传出了Chris的老师焦急的声音:"喂,是Chris的家长吗?你们的孩子又没来上课,不想参加考试了吗?"一 ...
- 「译」JUnit 5 系列:条件测试
原文地址:http://blog.codefx.org/libraries/junit-5-conditions/ 原文日期:08, May, 2016 译文首发:Linesh 的博客:「译」JUni ...
- 「译」JUnit 5 系列:扩展模型(Extension Model)
原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...
- JavaScript OOP 之「创建对象」
工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...
随机推荐
- 五、xadmin自定义插件2
以导入插件为例说明: 1.在xadmin-->plugins下面新建excel.py文件 2.新建ListExcelImportPlugin类,继承BaseAdminPlugin from xa ...
- Python Revisited Day 04 (控制结构与函数)
目录 4.1 控制结构 4.1.1 条件分支 4.1.2 循环 4.2 异常处理 4.2.1 捕获与产生异常 4.2.2 自定义异常 4.3 自定义函数 Tips 参数默认值为可变时 危险 4.3.1 ...
- C#格式化字符串大全
C#格式化字符串大全 分类: VS/C# 1.格式化货币(跟系统的环境有关,中文系统默认格式化人民币,英文系统格式化美元) string.Format("{0:C}" ...
- echarts使用笔记二:柱子堆叠
1.多个柱子堆叠效果,多用于各部分占比 app.title = '坐标轴刻度与标签对齐'; option = { title : { //标题 x : 'center', y : 5, text : ...
- [转帖]学习关于TTL
自己简单试了一下在家里与在公司里面服务器的连接: C:\Users\Administrator>tracert oms.inspur.com 通过最多 个跃点跟踪 到 oms.inspur.co ...
- mybtis逆向工程实战教程--条件查询
mabitis逆向工程进行条件查询:
- laravel 循环中子元素使用&符号嵌入到父级,经典版
/**ajax 获取企业名称 * * @param Request $request * * @return \Illuminate\Http\JsonResponse * @author lxw * ...
- vue+webpack项目打包后背景图片加载不出来问题解决
在做VUE +的WebPack脚手架项目打包完成后,在IIS服务器上运行发现项目中的背景图片加载不出来检查项目代码发现是因为CSS文件中,背景图片引用的路径问题;后来通过修改配置文件,问题终于解决了, ...
- vue-cli项目开发/生产环境代理实现跨域请求+webpack配置开发/生产环境的接口地址
一.开发环境中跨域 使用 Vue-cli 创建的项目,开发地址是 localhost:8080,需要访问非本机上的接口http://10.1.0.34:8000/queryRole.不同域名之间的访问 ...
- Selenium简单回顾
一.Selenium介绍 1.Selenium(浏览器自动化测试框架): Selenium 是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.支持的 ...