[BZOJ1196] [HNOI2006]公路修建问题

原创 2015年11月20日 23:25:51

传送门

http://www.lydsy.com/JudgeOnline/problem.php?id=1196

题目大意

给定一个图,有一级道路和二级道路,要求一级道路数量不少于k,求其生成树中最大边最小的值

题解

很明显的二分答案
验证时,用Kruskal判断,先扫一遍一级数值小于答案加入,如果条数小于k返回不行,扫所有数值小于答案的,条数为n-1的返回可以
反之不行

var
 x:array[0..50000,1..4]of longint;
 sum,fa:array[0..10005]of longint;
 i,j,k:longint;
 n,m,t:longint;
 a,b,c,d:longint;
 ans,l,r,mid,summ:longint;
procedure sort(l,r:longint);
var i,j,a,b:longint;
begin
 i:=l; j:=r; a:=x[(l+r) div 2,3];
 repeat
  while x[i,3]<a do inc(i);
  while a<x[j,3] do dec(j);
  if not(i>j) then
   begin
    b:=x[i,1]; x[i,1]:=x[j,1]; x[j,1]:=b;
    b:=x[i,2]; x[i,2]:=x[j,2]; x[j,2]:=b;
    b:=x[i,3]; x[i,3]:=x[j,3]; x[j,3]:=b;
    b:=x[i,4]; x[i,4]:=x[j,4]; x[j,4]:=b;
    inc(i); dec(j);
   end;
 until i>j;
 if l<j then sort(l,j);
 if i<r then sort(i,r);
end;

function get(a:longint):longint;
begin
 if fa[a]=a then exit(a);
 fa[a]:=get(fa[a]);
 exit(fa[a]);
end;

function check(ans:longint):longint;
begin
 summ:=0;
 for i:=1 to n do
  fa[i]:=i;
 for i:=2*m-2 downto 1 do
  begin
   if x[i,3]>ans then continue;
   if x[i,4]=0 then continue;
   a:=get(x[i,1]); b:=get(x[i,2]);
   if a<>b then begin inc(summ); fa[a]:=b; end;
  end;
 if summ<t then exit(0);
 for i:=1 to 2*m-2 do
  begin
   if x[i,3]>ans then continue;
   a:=get(x[i,1]); b:=get(x[i,2]);
   if a<>b then begin inc(summ); fa[a]:=b; end;
  end;
 if summ=n-1 then exit(1) else exit(0);
end;

begin
 readln(n,t,m);
 for i:=1 to m-1 do
  begin
   readln(a,b,c,d);
   x[i*2-1,1]:=a; x[i*2-1,2]:=b; x[i*2-1,3]:=c; x[i*2-1,4]:=1;
   x[i*2,1]:=a; x[i*2,2]:=b; x[i*2,3]:=d; x[i*2,4]:=0;
  end;
 sort(1,2*m-2); {x[i,3]}
 l:=1; r:=x[2*m-2,3];
 while l<r do
  begin
   mid:=(l+r)>>1;
   if check(mid)=1
   then r:=mid
   else l:=mid+1;
  end;
 writeln(l);
end.
版权声明:本文为博主原创文章,未经博主允许不得转载。

BZOJ1196: [HNOI2006]公路修建问题 二分+Kruskal

1196: [HNOI2006]公路修建问题 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1800  Solved: 1033 [S...
  • Oakley_
  • Oakley_
  • 2016年08月30日 21:21
  • 320

【BZOJ 1196】【HNOI 2006】公路修建问题 【二分+并查集】

题目跳转: http://www.lydsy.com/JudgeOnline/problem.php?id=1196DescriptionOI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅...

[BZOJ1196][HNOI2006]公路修建问题(最小生成树)

明天晚上就可以回家了!后天可以在车上颓废了哈哈哈哈
  • FromATP
  • FromATP
  • 2017年06月13日 07:18
  • 162

【BZOJ 1196】 [HNOI2006]公路修建问题

二分~ 有限制的最小生成树问题~

[BZOJ1196]HNOI2006公路修建问题|Kruskal|贪心|二分答案

二分答案很显然,贪心我没想到怎么贪。。     其实也挺显然的。。设当前二分到的答案是ans,将边排序(一级公路第一关键字,二级第二)后类似kruskal那样贪。。从小到大,如果一级公路费用,那直...

BZOJ 1196: [HNOI2006]公路修建问题 Kruskal/二分

题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1196题意:题解:其实也并不是最短路,只是用Kruskal的方法去判定符合条件的ans。 ...
  • yxg_123
  • yxg_123
  • 2017年03月06日 18:23
  • 109

BZOJ 1196 HNOI 2006 公路修建问题 二分答案+并查集

题目大意:给出n个点,要求把它们连成一棵树,有一些边可供选择,每一条遍都有一级公路和二级公路,问在一级公路不少于k的情况下最高花费的最低值是多少。 思路:二分答案,然后验证的时候先将边按照一...

BZOJ 1196: [HNOI2006]公路修建问题(二分+生成树)

1196: [HNOI2006]公路修建问题 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1477  Solved: 838 [Submit...

BZOJ 1196 HNOI2006 公路修建问题 二分答案+Kruskal

题目大意:给定一个无向图,一条边
  • PoPoQQQ
  • PoPoQQQ
  • 2014年11月23日 11:48
  • 1472

bzoj1196[HNOI2006]公路修建问题

Description OI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅游的人很多。然而,由于该岛屿刚刚开发不久,所以那里的交通情况还是很糟糕。所以,OIER Associatio...
  • zhb1997
  • zhb1997
  • 2014年06月14日 23:11
  • 487
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[BZOJ1196] [HNOI2006]公路修建问题
举报原因:
原因补充:

(最多只允许输入30个字)