c小红的图上划分(牛客127)

题意:

有一个无向图,有 n 个点 m 条边,q 个询问,每次给出 L,R,求将图划分为至少 L 个连通块,最多 R个连通块的最大划分价值,若不可划分输出 "NO ANSWER"。

图的划分定义为将图划分为一个或多个连通块,对于每个连通块,其点集为其边集中每一条边的两端点的集合,且点集内任意两点均可通过边集里的边互相到达。

划分价值定义为所有连通块边集中的最小边权。

分析:先将边从大到小排序;用并查集,如果新增边的点没有共同祖先,连通块就减1,只要判断连通块<=r即可满足条件,不用管l的值,因为减少一个连通块,也就是多增一条边,这条边一定会小于原来的值的,答案要的是最大值,所有不用管。

#include<bits/stdc++.h>

using namespace std;

const int N=2e5+10;

int fN,ansN;

struct A{

int u,v,w;

}eN;

int zx(int x){

if(fx==x)return x;//x没爸爸

else return fx=zx(fx);//找出爸爸的爸爸的。。

}

void h(int x,int y){

fzx(y)=zx(x);//x的最大祖先变成y最大祖先的爸爸;

}

bool cmp(A x,A y){

return x.w>y.w;

}

int main(){

int n,m,q;cin>>n>>m>>q;

for(int i=1;i<=m;i++)cin>>ei.u>>ei.v>>ei.w;

sort(e+1,e+m+1,cmp);

for(int i=1;i<=n;i++)fi=i;

int lt=n;

for(int i=1;i<=m;i++){

if(zx(ei.u)!=zx(ei.v)){

h(ei.u,ei.v);

lt--;

anslt=ei.w;

}

}

while(q--){

int l,r;

cin>>l>>r;

if(r<lt)cout<<"NO ANSWER"<<endl;

else cout<<ansr<<endl;

}

return 0;

}

相关推荐
倒流时光三十年12 分钟前
Java 内存模型(JMM)通俗解释
java·开发语言
wabs66624 分钟前
关于动态规划【力扣1143.最长公共子序列的思考】
算法·leetcode·动态规划
码兄科技39 分钟前
Java AI智能体开发实战:从零构建企业级智能应用指南
java·开发语言·人工智能
剑挑星河月44 分钟前
54.螺旋矩阵
java·算法·leetcode·矩阵
zh路西法1 小时前
【现代控制理论与卡尔曼滤波】从状态空间到Python仿真实现
开发语言·python
Evand J1 小时前
【论文复现】MATLAB例程,存在测距误差的WSN无锚点分布式自定位,《WSN中存在测距误差的无锚点分布式自定位方法》
开发语言·分布式·matlab·定位·导航·wsn
伏 念1 小时前
AI Coding 零基础实战教程
c语言·进程·预处理
你家人养牛1 小时前
OOC Relation Plugin:C 语言面向对象 开发的高效辅助工具
c语言·vscode
Robot_Nav1 小时前
MPPI 局部规划器实验设计讲解
人工智能·算法·mppi
想你依然心痛1 小时前
嵌入式C代码规范:MISRA-C 2012核心规则解读——类型安全与未定义行为深度剖析
c语言·安全·代码规范