题目大意:给你\(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. ubuntu部分常用操作指令记录

    # 以ROOT权限打开图形文件管理界面: sudo nautilus # 给某个文件添加可执行权限,例如: sudo chmod +x /usr/lib/jdk/bin/java # 修改某个文件或文 ...

  2. ubuntu下安装redis以及redis客户端在mac下的使用

    ubuntu下安装redis http://blog.fens.me/linux-redis-install/ 此方式利用brew安装包去获取最新的rdm客户端 资源失效了 https://www.j ...

  3. Ctags快速入门

    Ctags快速入门 在vim下阅读代码,特别是阅读不熟悉的代码时,ctags是一个提高效率的强大的工具. 1. ctags是什么? ctags可以将代码中的函数.方法.类.变量和其他的标识符进行索引, ...

  4. react-native 支持 gif 图片

    只需要在android/app/build.gradle中的dependencies字段中添加: compile 'com.facebook.fresco:animated-gif:0.13.0' 然 ...

  5. python中的编码转换

    今天遇到了一个问题,将字符串“\uxxxx\uxxxx”转换成汉字.网上查了很多资料都不行. 后来看到,发现一个函数就OK了. str = str.decode('unicode_escape') 等 ...

  6. cmd 环境变量设置方法详细解释

    cmd设置环境变量可以方便我们bat脚本的运行,但是要注意的是变量只在当前的cmd窗口有作用(局部生效),如果想要设置持久的环境变量需要我们通过两种手段进行设置:一种是直接修改注册表,另一种是通过我的 ...

  7. 最全面的HashMap和HashTable的区别

    找工作期间不少企业都会问到有关HashMap和HashTable两者直接的区别,很多博客里虽然有提及但总是没有那么全面,只是一些常用的不同,现在就我自己所总结的比较全面的不同,归纳以下: HashMa ...

  8. 算法(Algorithms)第4版 练习 1.3.25 1.3.24

    代码实现: //1.3.24 /** * remove the node following the node x * (and does nothing if the argument or the ...

  9. 分享知识-快乐自己:Mybatis缓存机制

    论缓存机制: 1):mybatis 提供了缓存机制减轻数据库压力,提高数据库性能. 2):mybatis 的缓存分为两级:一级缓存.二级缓存 3):一级缓存是SqlSession级别的缓存,缓存的数据 ...

  10. 【Codeforces】Gym 101156E Longest Increasing Subsequences LIS+树状数组

    题意 给定$n$个数,求最长上升子序列的方案数 根据数据范围要求是$O(n\log n)$ 朴素的dp方程式$f_i=max(f_j+1),a_i>a_j$,所以记方案数为$v_i$,则$v_i ...