P6954 [NEERC 2017] Connections 题解

P6954 [NEERC 2017] Connections 题解

题目链接

我的博客

前言

本篇总结:清空!

思路

因为删边之后还需要保证所有强连通关系不变,所以我们可以想到所有强连通分量之间的边一定可以删除。

接下来我们考虑如何删除保留一个强连通分量里面的边。

对于有向图来说,\(n\) 个结点强连通需要保证有不超过 \(2n\) 条边。

因此可以在一个强连通分量里面随意找一个点,对它跑一遍正图,一遍反图。(即跑内向树和外向树),保留所有树边。

最后如果删除的边还不满 \(2n\) 条,那么随便选没有被保留的边,直到满 \(2n\) 条边。

警示后人

多测一定要全部清空啊!!!包括 tarjan 的各种数组,最终的标记数组,以及存边的数组!

代码

const int N=1e5+10;
int T,n,m;
int out[N],tot;
//out:是(0)否(1)输出 i 边
//tot:保留的边的个数
struct edge{int nxt[N],to[N];int head[N],num_Edge=0;void add_Edge(int from,int t){nxt[++num_Edge]=head[from];to[num_Edge]=t;head[from]=num_Edge;}void clear(){//清空!for(int i=0;i<N-5;i++) head[i]=0;num_Edge=0;}
}e1,e2;
//e1:正向图,e2:反向图//tarjan板子
int dfn[N],low[N],dfscnt=0;
int scc[N],sc=0,st[N],top=0;
bool vis[N];
//以上的数组都需要清空!!!
void tarjan(int u){dfn[u]=low[u]=++dfscnt;st[++top]=u;vis[u]=1;for(int i=e1.head[u];i;i=e1.nxt[i]){int v=e1.to[i];if(!dfn[v]){tarjan(v);low[u]=min(low[u],low[v]);}else if(vis[v]){low[u]=min(low[u],dfn[v]);}}if(low[u]==dfn[u]){sc++;while(st[top]!=u&&top){scc[st[top]]=sc;vis[st[top]]=0;top--;}scc[st[top]]=sc;vis[st[top]]=0;top--;}
}
//内向树
void dfs1(int u){vis[u]=1;for(int i=e1.head[u];i;i=e1.nxt[i]){int v=e1.to[i];if(vis[v]) continue;if(scc[v]==scc[u]) {out[i]=1;dfs1(v);}} 
}
//外向树
void dfs2(int u){vis[u]=1;for(int i=e2.head[u];i;i=e2.nxt[i]){int v=e2.to[i];if(vis[v]) continue;if(scc[u]==scc[v]) {out[i]=1;dfs2(v);}}
}
void init(){e1.clear();e2.clear();for(int i=0;i<N-5;i++) out[i]=0;tot=0;	for(int i=1;i<=n;i++){dfn[i]=low[i]=0;scc[i]=0;}//尤其不要忘了这三个变量清空!sc=0;dfscnt=0;top=0;
}
void solve(){init();n=Read();m=Read();for(int i=1;i<=m;i++){int x=Read(),y=Read();e1.add_Edge(x,y);e2.add_Edge(y,x);}for(int i=0;i<N-5;i++) vis[i]=0;//每次用之前清空!!for(int i=1;i<=n;i++){if(!dfn[i]) tarjan(i);}for(int i=0;i<N-5;i++) vis[i]=0;for(int i=1;i<=n;i++){if(!vis[i]) dfs1(i);}for(int i=0;i<N-5;i++) vis[i]=0;for(int i=1;i<=n;i++){if(!vis[i]) dfs2(i);}for(int i=1;i<=m;i++) if(out[i]) tot++;for(int i=1;i<=m;i++){if(out[i]) continue;if(tot<2*n) out[i]=1,tot++;//如果不满 2n 条边}
//	puts("----");for(int i=1;i<=m;i++){if(out[i]) continue;printf("%d %d\n",e2.to[i],e1.to[i]);}
}
signed main(){T=Read();while(T--){solve();//多测函数好!}return 0; 
} 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/959158.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高级程序语言设计个人作业第四次

这个作业属于哪个课程 <班级的链接>这个作业要求在哪里 <作业链接>学号 092300303姓名 池博洋@目录运行程序(1)(2)求π近似值while方式:do while方式:实现逻辑表达式中的运算符for循环输出六行for循…

AI的泡沫与机遇:从技术神话到现实挑战

标签:AI发展, 就业市场, 技术反思, 行业趋势最近刷到一堆AI相关的新闻,感觉这玩意儿真是火得不行,但仔细一看,里面藏着不少值得琢磨的东西。一边是牛津研究院说AI能力可能被测试夸大,另一边阿里巴巴和谷歌又在疯狂…

什么是 Feed 流?

什么是 Feed 流?什么是 Feed 流? 摘要Feed 源自“被投喂的更新条目”,流指“连续滚动的呈现与计算范式”;Feed 流就是平台按流式形态持续投喂个性化内容给用户的机制与界面。 本质上,它是一个在实时反馈下运行的序…

preeee - when

Instuctions.scals package componentsimport chisel3.util.BitPat/** * LoongArch-C3指令集定义 * * 定义了CPU支持的21条LoongArch指令的BitPat模式 * 这些模式用于指令译码器进行指令识别和分类 * * 指令分类: * -…

调整 Halo2 Joe 主题友情链接页面样式

本人之前是使用 Typecho 建站的,后来接触到了 Halo,权衡后将网站内容都迁移到 Halo 建站上了,无论是 Typecho 还是 Halo 都有一款 Joe 主题,我个人非常喜欢这款主题,决定迁移到 Halo 也是因为 Joe 主题移植的很成…

CF1463E Plan of Lectures

手伤了不是很能打代码,写短一点。 相邻限制缩一起,\(a_i \to i\) 连边跑拓扑序即可。

基于单片机的元胞自动机仿真系统设计 - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

251107

251107我又分不清梦和现实,梦到死去的人我知道是假的,但如果梦到活人,我又该怎么分辨真假,说不定死去的人也是真的,只是我还没睡醒。最近我的食欲大了很多,烟开始抽的少了,没有一天是天亮,黑夜胜过白昼,偶尔见…

2025年防水补漏企业TOP5:漏水维修、防水翻新、漏水检测

在建筑维护领域,防水补漏是保障建筑安全与使用寿命的关键环节。据中国建筑防水协会2024年度报告显示,全国建筑渗漏率仍高达80%以上,其中因非专业施工导致二次渗漏的比例占65%。面对市场上鱼龙混杂的服务providers,…

(鲜花)万宁五子棋 v0.2

突然发现以前做的蛮有意思的一玩意。就一挺 naive 的东西,允许两个玩家在同一电脑上轮流下棋,W,A,S,D 移动棋子,Enter 下棋,会自动判定五子连珠,然后就没了。 后续可能会更新点人机什么的东西,看兴致。 源码如下…

ansible + docker compose, RustFS MNMD 架构的一键部署之道

RustFS 有三种安装模式:单机单盘(SNSD)、单机多盘(SNMD)以及多机多盘(MNMD)。其中多机多盘属于集群式安装,也是企业使用最多的模式。多机多盘意味着要在每个服务器上都安装 RustFS 实例,本文探索用 ansible +…

2025年海外仓服务最新推荐企业,欧洲海外仓、美国海外仓、亚马逊海外仓、TEMU海外仓、独立站海外仓服务商解析

当前跨境电商与外贸企业对海外仓的需求日益精细化,仓储成本控制、订单处理效率、本土化服务等核心诉求持续升级,但市场上服务商资质参差不齐,部分企业存在库内操作效率低、系统稳定性不足、售后响应滞后等问题,导致…

实用指南:RSA加密从原理到实践:Java后端与Vue前端全栈案例解析

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Ubuntu 中创建全局可访问的共用目录

第一步:创建全局可访问的共用目录在根目录下创建目录(需 root 权限)执行以下命令在根目录(/)下创建名为shared的共用目录: sudo mkdir /shared 设置权限为 “任何人可访问”为确保所有用户(包括系统用户、普通用…

开源 C++ QT QML 开发(十五)通讯--http下载 - 实践

开源 C++ QT QML 开发(十五)通讯--http下载 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas&quo…

2025年11月不锈钢加工装饰制品优质厂家推荐榜:加工、屏风、栏杆等品类精选

当前酒店、别墅、商业空间等场景对不锈钢装饰制品的需求愈发精细化,材质纯度、工艺精度、场景适配性等核心诉求不断升级,但市场上厂家资质良莠不齐,部分产品存在材质以次充好、焊接工艺粗糙、售后响应滞后等问题,导…

P3978 概率论

膜拜 wck做法 考虑一个经典问题:n个点的二叉树数量是多少。考虑转括号序,一个节点是一个括号,左子树放在括号内,右子树放在括号右侧。可得 \(n\) 个点二叉树数量为 \(Cat_n\)。 我们注意到叶子在括号序上形如 \(()…

从iPhone转移到itel手机的联系人转移指南 - 实践

从iPhone转移到itel手机的联系人转移指南 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", …

JT808,JT1078 —— AAC编码 —— 部标机语音对讲Java实现

一、基础知识1、JT808,JT1078 协议了解① JT/T 808 是中国交通运输行业关于车载终端与监管平台之间数据交换的通信协议,核心目标是实现车辆运行状态、报警事件、定位数据、远程控制等信息的标准化传输。 ② JT/T 1…

DP 总结

1.如果有类似与 \(f{i,j,k}=[0,1]\) 的而且要求 \(f{i,j,k}=1\) 时\(k:{max,min}\)情况,可以转成 \(f{i,j}=k\) ,如果有值就代表原来是 1。 2.如果区间 DP 有一个区间不好做,考虑对于另外一个区间进行 DP。可以自由转…