SPOJ 1437 Longest path in a tree
来源:互联网 发布:linux创建hadoop用户 编辑:程序博客网 时间:2024/06/05 22:40
求树的直径,两次bfs可求
原理: 设起点为u,第一次BFS找到的终点v一定是树的直径的一个端点
证明: 1) 如果u 是直径上的点,则v显然是直径的终点(因为如果v不是的话,则必定存在另一个点w使得u到w的距离更长,则于BFS找到了v矛盾)
2) 如果u不是直径上的点,则u到v必然于树的直径相交(反证),那么交点到v 必然就是直径的后半段了
(引用)证明:
树的直径是指树的最长简单路。求法: 两遍BFS :先任选一个起点BFS找到最长路的终点,再从终点进行BFS,则第二次BFS找到的最长路即为树的直径;原理: 设起点为u,第一次BFS找到的终点v一定是树的直径的一个端点
证明: 1) 如果u 是直径上的点,则v显然是直径的终点(因为如果v不是的话,则必定存在另一个点w使得u到w的距离更长,则于BFS找到了v矛盾)
2) 如果u不是直径上的点,则u到v必然于树的直径相交(反证),那么交点到v 必然就是直径的后半段了
所以v一定是直径的一个端点,所以从v进行BFS得到的一定是直径长度
#include <iostream>#include <cstdio>#include <cstring>#include <queue>#include <vector>using namespace std;const int maxn = 10000+10;vector<int>ve[maxn];struct Node{ int v; int dis; Node(){}/***这里要注意*/ Node(int v, int dis):v(v),dis(dis){}};bool vis[maxn];Node bfs(int x){ Node cnt = Node(x, 0); queue<Node>que; memset(vis,0,sizeof(vis)); vis[x] = 1; que.push(cnt); while(!que.empty()){ Node cmp = que.front(); que.pop(); cnt = cmp; vis[cmp.v] = 1;///找过的点不再重复// vis[cmp.v] = 0; int s = ve[cmp.v].size(); for(int i=0; i<s;++i){ if(vis[ve[cmp.v][i]])continue; vis[ve[cmp.v][i]] = 1; que.push(Node(ve[cmp.v][i],cmp.dis+1)); } } return cnt;}int main(){ int n; int x, y; scanf("%d",&n); for(int i = 0; i < n-1; ++i){ scanf("%d%d",&x,&y); ve[x].push_back(y);ve[y].push_back(x); } printf("%d\n",bfs(bfs(1).v).dis); return 0;}
0 0
- SPOJ 1437 Longest path in a tree
- 【SPOJ-PT07Z】Longest path in a tree【DFS/BFS】【树的直径】
- leetcode Longest Increasing Path in a Matrix
- 329. Longest Increasing Path in a Matrix
- [LeetCode] Longest Increasing Path in a Matrix
- Longest Increasing Path in a Matrix
- leetcode: Longest Increasing Path in a Matrix
- Leetcode: Longest Increasing Path in a Matrix
- Longest Increasing Path in a Matrix
- leetcode:Longest Increasing Path in a Matrix
- [LeetCode]Longest Increasing Path in a Matrix
- [Leetcode]Longest Increasing Path in a Matrix
- 329. Longest Increasing Path in a Matrix
- Longest Increasing Path in a Matrix
- Longest Increasing Path in a Matrix | leetcode
- LeetCode Longest Increasing Path in a Matrix
- 【Leetcode】Longest Increasing Path in a Matrix
- LeetCode:Longest Increasing Path in a Matrix
- java 线程通信
- 如何在编程生涯中有一个好的开端
- #初学算法#分治策略---最大子数列的暴力求解和分治求解对比
- Java常用代码片段汇总
- 编译相关的头文件及动态库相关的
- SPOJ 1437 Longest path in a tree
- 全球排名前50网站都用什么语言开发的?
- STM32 中 BIT_BAND(位段/位带)和别名区使用入门
- 数据挖掘学习指引<一>
- NYOJ奇偶数分离
- 【Java.Web】Session —— Java Web中的Session概述
- 对接口的深刻理解
- DataGridView控件用法(二):为每行记录最后加“编辑”-“删除”按钮列
- html css属性