记录编号 473410 评测结果 AAAAAAAAAA
题目名称 [HZOI 2016]公路修建2 最终得分 100
用户昵称 GravatarDedsec 是否通过 通过
代码语言 C++ 运行时间 0.645 s
提交时间 2017-11-08 17:23:46 内存使用 17.10 MiB
显示代码纯文本
#include<iostream>
#include<cstring>
#include<cstdio>
#include<string>
#include<queue>
#include<vector>
#include<algorithm>
#include<cmath>
#include<stack>
#include<map>
using namespace std;
#define R register
#define ll long long
#define fo(i,a,b) for(R int (i)=(a);(i)<=(b);++(i))
#define debug(x) cout<<#x<<"="<<x<<'\n'
struct node{int x,y,v,ty,afo;}a[800000];
int n,k,m,ans=0,fa[400000],cnt=0;
bool comp(const node &a,const node &b){return a.v<b.v;}
int find(int x){return fa[x]=fa[x]==x?x:find(fa[x]);}
int main()
{
	freopen("hzoi_road2.in","r",stdin);
	freopen("hzoi_road2.out","w",stdout);
	scanf("%d%d%d",&n,&k,&m);
	fo(i,1,m-1)
		scanf("%d%d%d%d",&a[i].x,&a[i].y,&a[i].v,&a[i+m-1].v),a[i+m-1].x=a[i].x,a[i+m-1].y=a[i].y,a[i].ty=1,a[i+m-1].ty=2;
	fo(i,1,n)fa[i]=i;
	sort(a+1,a+m*2-1,comp);
	fo(i,1,m*2-2)
	{
		if(a[i].ty==1)continue;
		R int f1=find(a[i].x),f2=find(a[i].y);
		if(f1!=f2)fa[f1]=f2,ans=a[i].v,a[i].afo=1;
	}
	fo(i,1,m*2-2)
	{
		if(cnt==k)break;
		if(a[i].ty==2||a[i].afo)continue;
		cnt++,ans=max(a[i].v,ans),a[i].afo=1;
	}
	cout<<ans;
	return 0;
}