题目大意:给你\(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. vuex原理笔记

    本文总结自: https://tech.meituan.com/vuex-code-analysis.html, 将要点提炼为笔记,以便不时之需,安不忘危. 核心可分为两部分: 1.vue.use(V ...

  2. deepin 安装微信与QQ

    安装QQ sudo apt-get install deepin.com.qq.im 安装微信 sudo apt-get install deepin.com.wechat 附录 其他安装包 http ...

  3. Spark- Linux下安装Spark

    Spark- Linux下安装Spark 前期部署 1.JDK安装,配置PATH 可以参考之前配置hadoop等配置 2.下载spark-1.6.1-bin-hadoop2.6.tgz,并上传到服务器 ...

  4. CentOS7 默认防火墙firewalld

    firewalld基础 firewalld是CentOS7源生支持的防火墙,firewalld最大的好处有两个:支持动态更新,不用重启服务:第二个就是加入了防火墙的“zone”概念. firewall ...

  5. python打印字体颜色

        格式:\033[显示方式;前景色;背景色m 显示方式           意义-------------------------0                终端默认设置1         ...

  6. JSP 使用<%@include%>报Duplicate local variable path 错误 解决方法

    错误提示:Multiple annotations found at this line:- Duplicate local variable path- Duplicate local variab ...

  7. Openstack web 添加和删除按钮

    注:当前已经时候用smaba将openstack环境的源码共享到windows系统上,并使用pycharm进行代码编辑和修改(参见openstack开发环境搭建).如下图:

  8. CF-845C

    C. Two TVs time limit per test 2 seconds memory limit per test 256 megabytes input standard input ou ...

  9. VMware10中安装centos7没有可用的网络设备

    1.问题描述 centos7安装到虚拟机无法上网   2.安装环境 win7 x64  WM 10.01 iso  CentOS-7-x86_64-DVD-1503-01.iso  {4.01G}   ...

  10. MySQL 之 扩展例子

    扩展例子 插入一条记录 INSERT INTO 表名 [(字段1,…,字段n)] VALUES (值1,…,值n) 插入查询的结果 INSERT INTO 表名 (字段1,…,字段n) VALUES ...