题意:n个点,m条边,每条边的距离是1,求两个点之间的最远距离。
解:从1开始找一条最远路,假设到达的点为x,再以x为起点,找一遍最远路。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<cmath>
#include<map>
#include<queue>
using namespace std;
#define mem(a,b) memset(a,b,sizeof(a))
const int INF=0x3f3f3f3f;
const int Max=1e5+10;
int dis[Max],cnt=1;
int vis[Max],head[Max];
priority_queue<pair<int,int>,vector<pair<int,int> >,less<pair<int,int> > >q;