题目大意:给你\(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. 【转】Java中的代码点与代码单元

    转载自:http://blog.csdn.net/xujinsmile/article/details/8526387 最近看core java,之前一直不明白,看了不少帖子和博客,总算搞明白了. J ...

  2. 【转载】帧缓冲驱动程序分析及其在BSP上的添加

    原文地址:(四)帧缓冲驱动程序分析及其在BSP上的添加 作者:gfvvz 一.BSP修改及其分析   1. BSP中直接配置的四个寄存器 S3C6410数据手册的第14.5部分是显示控制器的编程模型部 ...

  3. poj 1469 COURSES (二分图模板应用 【*模板】 )

    COURSES Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 18454   Accepted: 7275 Descript ...

  4. jQuery(expression, [context])

    jQuery(expression, [context])         返回值:jQuery 概述 这个函数接收一个包含 CSS 选择器的字符串,然后用这个字符串去匹配一组元素. jQuery 的 ...

  5. html5 手写的canvas实现

    试用支持canvas的浏览器,无JS依赖,运用新的HTML5技术DrawBoard.renderDrawer('myHandWrite',{  penColor:'#FF0000',  penWidt ...

  6. BZOJ 1609 [Usaco2008 Feb]Eating Together麻烦的聚餐:LIS & LDS (nlogn)

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1609 题意: 给你一个只由数字"1,2,3"组成的序列a[i],共n个 ...

  7. SpringMVC框架<mvc:default-servlet-handler/>的作用

    1.创建一个新工程 Eclipse下新建一个web项目,File>New>Dynamic Web Project     2.添加Jar包     3.配置Web.xml     4.配置 ...

  8. 从结果推断过程----->使用System.out和Root Device

    刚才解决了一个App中更新的逻辑问题.出问题之后发现,有很多处调用了更新,后来都不知道是哪里改写了SharedPreferences. 然后一直在挨个寻找每一处更新的地方,花了很多时间. 最后直接使用 ...

  9. CodeForces - 1005E2:Median on Segments (General Case Edition) (函数的思想)

    You are given an integer sequence a1,a2,…,ana1,a2,…,an. Find the number of pairs of indices (l,r)(l, ...

  10. poj3709 K-Anonymous Sequence[贪心+斜率优化dp]

    地址 n个数,可进行把一个数减小的操作,代价为减小的值.现求使数列任意一个数都存在至少k-1个数和他相同,问操作的最小代价. 可以先考虑最小的数,由于只能减,所以必须得至少k-1个数减为最小数,贪心策 ...