题目大意:给你\(n\)个点,\(m\)条边,每条边上有两个权值:一级和二级的。选\(n-1\)条边使这个图连通,并至少有\(k\)个一级边,求花费最多的一条边最小值及方案。

最大值最小,肯定会先想到二分,如何判定?其实我们仔细读题,应该发现,他不是一个完整的最小生成树,因为没有要求边权和最小,只是需要借鉴\(Kruskal\)的建树方式,每次尽量先把一级边选出来,最后如果有点和他们不连通,那么不合法。之前说的是二分判定的过程。最后我们把方案输出即可。

注意我不知道为啥非要两种边分别存而不是存在一起判奇偶...而且读入非常玄学...被水题卡非常不爽。

\(Kruskal\)貌似不用考虑边数是不是\(n-1\)。

#include<cstdio>
#include<algorithm>
#include<queue>
#define maxn 10090 using namespace std; int n,m,l=0,r,tot,k;
int fa[maxn];
struct node{
int f,t,w,op,id;
}edge[maxn<<1],e[maxn<<1];
struct cellur{
int id,op;
};
bool operator < (const cellur &a,const cellur &b)
{
return a.id>b.id;
}
priority_queue<cellur>q; int getf(int x)
{
if(x==fa[x]) return x;
else return fa[x]=getf(fa[x]);
} bool check(int lim)
{
int qwq=0;
for(int i=1;i<=n;i++) fa[i]=i;
for(int i=1;i<=m;i++)
{//先处理1号公路
if(e[i].w>lim) continue;
int pp=getf(e[i].f);
int qq=getf(e[i].t);
if(pp==qq) continue;
fa[qq]=pp;
qwq++;
}
if(qwq<k) return 0;
for(int i=1;i<=m;i++)
{//再处理2号公路
if(edge[i].w>lim) continue;
int pp=getf(edge[i].f);
int qq=getf(edge[i].t);
if(pp==qq) continue;
fa[qq]=pp;
}
int scc=0;
for(int i=1;i<=n;i++)
{
if(fa[i]==i) scc++;
if(scc>1) return 0;
}
return 1;
} int main()
{
scanf("%d%d%d",&n,&k,&m);
m--;
for(int i=1;i<=m;i++)
{
int x=0,y=0,z=0,q=0;
scanf("%d%d%d%d",&x,&y,&z,&q);
e[i].f=x,e[i].t=y,e[i].w=z,e[i].id=i;
edge[i].f=x,edge[i].t=y,edge[i].w=q,edge[i].id=i;
r=max(r,q);r=max(r,z);
}
while(l<r)
{
int mid=(l+r)>>1;
if(check(mid)) r=mid;
else l=mid+1;
}
printf("%d\n",l);
for(int i=1;i<=n;i++) fa[i]=i;
for(int i=1;i<=m;i++)
{//先处理1号公路
if(e[i].w>l) continue;
int pp=getf(e[i].f);
int qq=getf(e[i].t);
if(pp==qq) continue;
fa[qq]=pp;
q.push((cellur){e[i].id,1});
}
for(int i=1;i<=m;i++)
{//再处理2号公路
if(edge[i].w>l) continue;
int pp=getf(edge[i].f);
int qq=getf(edge[i].t);
if(pp==qq) continue;
fa[qq]=pp;
q.push((cellur){edge[i].id,2});
}
while(!q.empty())
{
cellur qwq=q.top();
q.pop();
printf("%d %d\n",qwq.id,qwq.op);
}
return 0;
}

LuoguP2323 [HNOI2006]公路修建问题 【最小生成树+二分】By cellur925的更多相关文章

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

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

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

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

  3. BZOJ1196 [HNOI2006]公路修建问题 【二分 + Kruskal】

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

  4. BZOJ 1196 [HNOI2006]公路修建问题(二分答案+并查集)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1196 [题目大意] 对于每条可能维修的公路可选择修一级公路或者二级公路,价值不同 要求 ...

  5. BZOJ 1196 [HNOI2006]公路修建问题:二分 + 贪心生成树check(类似kruskal)

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1196 题意: n个城市,m对城市之间可以修公路. 公路有两种,一级公路和二级公路,在第i对 ...

  6. BZOJ-1196 公路修建问题 最小生成树Kruskal+(二分??)

    题目中一句话,最大费用最小,这么明显的二分的提示(by 以前morestep学长的经验传授)...但完全没二分,1A后感觉很虚.. 1196: [HNOI2006]公路修建问题 Time Limit: ...

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

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

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

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

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

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

随机推荐

  1. HTML5/CSS3鼠标滑过图片滤镜动画效果

    在线演示 本地下载

  2. c# wpf ComboBox 动态下拉框 及 动态默认值设定

    1.下拉框声明 <ComboBox x:Name="DirComboBox" Width="150" Height="18" Marg ...

  3. Python爬虫 —— 抓取美女图片

    代码如下: #coding:utf-8 # import datetime import requests import os import sys from lxml import etree im ...

  4. java中判断字符串是否相等有两种方法:

    1.用“==”运算符,该运算符表示指向字符串的引用是否相同,比如: String a="abc";String b="abc",那么a==b将返回true.这是 ...

  5. blog集合

    godiscoder的技术blog 一个不错的技术架构设计blog MySQLOPS 数据库与运维自动化技术分享 stone的技术blog 陈皓专栏 风雪涟漪的技术blog 华为首席科学家 张宴技术b ...

  6. 苹果手机app试玩赚钱平台汇总

    注意: 微信扫码下载,绑定手机号和微信.才能提现 每天3点更新任务,4点最多! | 平台 | 提现额 | 任务量| 推荐强度 | 扫码 | 1.小鱼,10元,大量,强推! →点开扫码 2.天天飞燕,5 ...

  7. 集训Day12

    快乐 快乐就完事了 今天把Trie树 / 可持久化Trie树搞了一下 Trie树可以维护区间最大异或和 具体就是区间异或和 -> 区间两个前缀异或和的异或 然后就变成了 "从n个数里找 ...

  8. BZOJ_2111_[ZJOI2010]Perm 排列计数_树形DP+组合数学

    Description 称一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2<=i<=N时,Pi>Pi/2. 计算1,2,...N的排列中有多少是Magic ...

  9. requirejs的打包工具r.js

    不建议用命令行,还是用配置文件比较方便--build.js. 我的build.js文件内容大概如下: ( { appDir : './', baseUrl : './scripts', dir : ' ...

  10. Mesos的quorum配置引发的问题

    Mesos安装完毕后,发现agent无法和master关联(通过WebUI的agent页面无法看到agent信息),查看日志显示: Elected as the leading master! sta ...