https://www.luogu.org/problemnew/show/P2323

【题目描述】

OI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅游的人很多。然而,由于该岛屿刚刚开发不久,所以那里的交通情况还是很糟糕。所以,OIER Association组织成立了,旨在建立OI island的交通系统。 OI island有n个旅游景点,不妨将它们从1到n标号。现在,OIER Association需要修公路将这些景点连接起来。一条公路连接两个景点。公路有,不妨称它们为一级公路和二级公路。一级公路上的车速快,但是修路的花费要大一些。 OIER Association打算修n-1条公路将这些景点连接起来(使得任意两个景点之间都会有一条路径)。为了保证公路系统的效率, OIER Association希望在这n-1条公路之中,至少有k条(0≤k≤n-1)一级公路。OIER Association也不希望为一条公路花费的钱。所以,他们希望在满足上述条件的情况下,花费最多的一条公路的花费尽可能的少。而你的任务就是,在给定一些可能修建的公路的情况下,选择n-1条公路,满足上面的条件。

【输入输出格式】

  • 输入格式

第一行有三个数n(1≤n≤10000),k(0≤k≤n-1),m(n-1≤m≤20000),这些数之间用空格分开。 N和k如前所述,m表示有m对景点之间可以修公路。以下的m-1行,每一行有4个正整数a,b,c1,c2 (1≤a,b≤n,a≠b,1≤c2≤c1≤30000)表示在景点a与b 之间可以修公路,如果修一级公路,则需要c1的花费,如果修二级公路,则需要c2的花费。

注意,在实际评测时,将只会有 m−1m-1m−1 条公路。

  • 输出格式

输出的第一行有一个数据,表示花费最大的公路的花费。

接下来的 n-1行,每行有两个正整数 t和 p , t 和 p 表示在输入的第 t 对(按照输入的顺序,从1开始标号)景点之间修建 p级公路。

n−1 条公路的输出必选 t 的大小递增,如果有多个方案使花费最大的公路花费最小,那么输出任意一个都可以。

【输入输出样例】

  • 输入样例

    4 2 5
    1 2 6 5
    1 3 3 1
    2 3 9 4
    2 4 6 1
  • 输出样例
    6
    1 1
    2 1
    4 2

  本题是一道半裸的模板题,可以有两种做法,看到关键字“最大的最小值”,可以考虑使用二分答案,本篇博客主要讲解第二种方法——最小生成树。

  首先将一级公路和二级公路分别排序,然后从小到大选k条边加入生成树,剩下的边在二级公路中选择。

  

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#define maxn 20010 using namespace std; int n,m,k,f[],vis[maxn][]; struct road
{
int u,v,w,tim;
}e1[maxn],e2[maxn]; int max(int x,int y)
{
return x<y?y:x;
} int getf(int node)
{
if(node==f[node])
return node;
f[node]=getf(f[node]);
return f[node];
} void meg(int x,int y)
{
int t1=getf(x),t2=getf(y);
if(t1==t2)
return;
f[t2]=t1;
} void qsort(int l,int r,int flag)
{
int i=l,j=r;
if(flag==) {
road mid=e1[(l+r)/];
do
{
while(e1[i].w<mid.w) i++;
while(e1[j].w>mid.w) j--;
if(i<=j)
{
road t=e1[i];
e1[i]=e1[j];
e1[j]=t;
i++;j--;
}
}while(i<=j);
}
else
{
road mid=e2[(l+r)/];
do
{
while(e2[i].w<mid.w) i++;
while(e2[j].w>mid.w) j--;
if(i<=j)
{
road t=e2[i];
e2[i]=e2[j];
e2[j]=t;
i++;j--;
}
}while(i<=j);
}
if(l<j) qsort(l,j,flag);
if(i<r) qsort(i,r,flag);
} int main()
{
scanf("%d%d%d",&n,&k,&m);
for(int i=;i<m;i++)
{
int x,y,c1,c2;
scanf("%d%d%d%d",&x,&y,&c1,&c2);
e1[i].u=x;e1[i].v=y;e1[i].tim=i;e2[i]=e1[i];
e1[i].w=c1;e2[i].w=c2;
}
qsort(,m-,);
qsort(,m-,);
for(int i=;i<=n;i++)
f[i]=i;
int num=,ans=-;
for(int i=;i<=k;i++)
{
while(getf(e1[num].u)==getf(e1[num].v))
num++;
meg(e1[num].u,e1[num].v);
vis[e1[num].tim][]=;
ans=max(e1[num].w,ans);
}
num=;
for(int i=k+;i<n;i++)
{
while(getf(e2[num].u)==getf(e2[num].v))
num++;
meg(e2[num].u,e2[num].v);
vis[e2[num].tim][]=;
ans=max(e2[num].w,ans);
}
printf("%d\n",ans);
for(int i=;i<m;i++)
{
if(vis[i][])
printf("%d 1\n",i);
else if(vis[i][])
printf("%d 2\n",i);
}
return ;
}

HNOI2006公路修建问题的更多相关文章

  1. 【最小生成树】BZOJ 1196: [HNOI2006]公路修建问题

    1196: [HNOI2006]公路修建问题 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1435  Solved: 810[Submit][Sta ...

  2. bzoj 1196: [HNOI2006]公路修建问题 二分+并查集

    题目链接 1196: [HNOI2006]公路修建问题 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1576  Solved: 909[Submit ...

  3. BZOJ 1196: [HNOI2006]公路修建问题( MST )

    水题... 容易发现花费最大最小即是求 MST 将每条边拆成一级 , 二级两条 , 然后跑 MST . 跑 MST 时 , 要先加 k 条一级road , 保证满足题意 , 然后再跑普通的 MST . ...

  4. BZOJ_1196_[HNOI2006]公路修建问题_kruskal+二分答案

    BZOJ_1196_[HNOI2006]公路修建问题_kruskal+二分答案 题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1196 分析: ...

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

    1196: [HNOI2006]公路修建问题 Time Limit: 1 Sec  Memory Limit: 162 MB 题目连接 http://www.lydsy.com/JudgeOnline ...

  6. 洛谷 P2323 [HNOI2006]公路修建问题 解题报告

    P2323 [HNOI2006]公路修建问题 题目描述 输入输出格式 输入格式: 在实际评测时,将只会有m-1行公路 输出格式: 思路: 二分答案 然后把每条能加的大边都加上,然后加小边 但在洛谷的题 ...

  7. 1196/P2323: [HNOI2006]公路修建问题

    1196: [HNOI2006]公路修建问题 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2191  Solved: 1258 Descriptio ...

  8. 洛谷P2323 [HNOI2006] 公路修建问题 [二分答案,生成树]

    题目传送门 公路修建问题 题目描述 OI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅游的人很多.然而,由于该岛屿刚刚开发不久,所以那里的交通情况还是很糟糕.所以,OIER Associa ...

  9. BZOJ1196: [HNOI2006]公路修建问题

    Description OI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅游的人很多.然而,由于该岛屿刚刚开发不久,所以那里的交通情况还是很糟糕.所以,OIER Association组织 ...

  10. 1196: [HNOI2006]公路修建问题 - BZOJ

    Description OI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅游的人很多.然而,由于该岛屿刚刚开发不久,所以那里的交通情况还是很糟糕.所以,OIER Association组织 ...

随机推荐

  1. Git 工具 - 储藏(Stashing)

    储藏(Stashing) 经常有这样的事情发生,当你正在进行项目中某一部分的工作,里面的东西处于一个比较杂乱的状态,而你想转到其他分支上进行一些工作.问题是,你不想提交进行了一半的工作,否则以后你无法 ...

  2. pip install beautifulsoup4.失败

    在学习python爬虫时,用到bs4解析网页,开始遇到安装bs出错 Collecting beautifulsoup4Exception:Traceback (most recent call las ...

  3. 本地安装了Maven但Eclipse的Preferences中没有Maven怎么办?

    Maven是帮助我们进行项目构建管理的一个重要工具,Emmmmmm,因为还是个小白,这里就不装大明白了,就我目前了解Maven是用来管理jar包的,想要在Eclipse上运行就要将它集成到Eclips ...

  4. intptr_t 指针(转)

    reference:http://muchong.com/bbs/ 对于64为系统: typedef signed char int8_t; typedef short int int16_t; ty ...

  5. php留言板程序

    =================== 先创建note.php <html><head><title>PHP留言本</title></head&g ...

  6. hadoop2.6.0高可靠及yarn 高可靠搭建

    以前用hadoop2.2.0只搭建了hadoop的高可用,但在hadoop2.2.0中始终没有完成YARN HA的搭建,直接下载了hadoop最新稳定版本2.6.0完成了YARN HA及HADOOP ...

  7. Problem A: STL——灵活的线性表

    Description 数组和链表是我们熟知的两种线性结构,但是它们不够灵活(不能同时实现直接插入.删除和访问操作),给你若干种操作,你能通过一种灵活的容器,实现它们的功能吗? 操作1:Build a ...

  8. ie9上传后下载json

    1.保持后台控制器返回的数据为字符串格式 2.js:dataType类型保持为html格式 dataType: 'html',//默认就是html类型,不写对火狐有影响 3.将上传后后台返回的字符串转 ...

  9. IOS 极光推送自定义通知遇到的一些坑

    主要方法: //自定义推送 - (void)networkDidReceiveMessage:(NSNotification *)notification { NSDictionary * userI ...

  10. winform 写入txt(可以连续性的在文本内容后面追加)

    在上一篇写入txt的时候,不可以在后面追击,调用一次,以前的同名的文本就会覆盖掉.这次的功能会修改上次这个小bug StreamWriter sw = new StreamWriter("D ...