由题可得,选择性的翻修路面,连接每个路口,路口可视为结点,道路可视为边,则原题意为求最小生成树,故可用Kruskal解决。
using namespace std;
const int N=8050;
int n,m;
int x,y,z;
int p[N];
int cnt;
int ans=-1;
struct Node{
int u,v,w;
}g[N];
bool cmp(Node n1,Node n2){
return n1.w<n2.w;
}
void init(){
for(int i=1;i<=n;i++) p[i]=i;
}
int find(int x){
if(x==p[x]) return p[x];
return p[x]=find(p[x]);
}
void kruskal(){
int fx=find(x),fy=find(y);
if(fx==fy) return;
p[fx]=fy;
cnt+=1;
ans = max(ans, z);
return ;
}
int main(){
ios::sync_with_stdio(false);
cin>>n>>m;
for(int i=1;i<=m;i++){
cin>>g[i].u>>g[i].v>>g[i].w;
}
init();
sort(g+1,g+m+1,cmp);
for(int i=1;i<=m;i++){
x=g[i].u;
y=g[i].v;
z=g[i].w;
kruskal();
}
cocout<<cnt<<" "<<ans;
return 0;
}