记录编号 473286 评测结果 AAAAAAAAAA
题目名称 [HZOI 2016]公路修建 最终得分 100
用户昵称 GravatarDedsec 是否通过 通过
代码语言 C++ 运行时间 0.212 s
提交时间 2017-11-08 16:00:58 内存使用 1.99 MiB
显示代码纯文本
  1. #include<iostream>
  2. #include<cstring>
  3. #include<cstdio>
  4. #include<string>
  5. #include<queue>
  6. #include<vector>
  7. #include<algorithm>
  8. #include<cmath>
  9. #include<stack>
  10. #include<map>
  11. using namespace std;
  12. #define R register
  13. #define ll long long
  14. #define fo(i,a,b) for(R int (i)=(a);(i)<=(b);++(i))
  15. #define debug(x) cout<<#x<<"="<<x<<'\n'
  16. struct node{int x,y,v,ty,afo;}a[80000];
  17. int n,k,m,ans=0,fa[40000],cnt=0;
  18. bool comp(const node &a,const node &b){return a.v<b.v;}
  19. int find(int x){return fa[x]=fa[x]==x?x:find(fa[x]);}
  20. int main()
  21. {
  22. freopen("hzoi_road.in","r",stdin);
  23. freopen("hzoi_road.out","w",stdout);
  24. scanf("%d%d%d",&n,&k,&m);
  25. fo(i,1,m-1)
  26. 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;
  27. fo(i,1,n)fa[i]=i;
  28. sort(a+1,a+m*2-1,comp);
  29. fo(i,1,m*2-2)
  30. {
  31. if(cnt==k)break;
  32. if(a[i].ty==2)continue;
  33. R int f1=find(a[i].x),f2=find(a[i].y);
  34. if(f1!=f2)fa[f1]=f2,cnt++,ans=a[i].v,a[i].afo=1;
  35. }
  36. fo(i,1,m*2-2)
  37. {
  38. if(a[i].afo)continue;
  39. R int f1=find(a[i].x),f2=find(a[i].y);
  40. if(f1!=f2)fa[f1]=f2,ans=max(a[i].v,ans);
  41. }
  42. cout<<ans;
  43. return 0;
  44. }