当前位置: 首页 > news >正文

信息学奥赛一本通 1524:旅游航道

【题目链接】

ybt 1524:旅游航道

【题目考点】

1. 图论:割边(桥)

【解题思路】

一个星球是一个顶点,一条航道是一条无向边,任意两星球之间可以通过航道到达,说明该图是连通图。可以认为输入数据中没有重边和自环。
“如果某一条航道的删除使得一些星球不能到达,那么这条航道是不能删除的,称之为「主要航道」”,显然主要航道就是桥。
该题求一个连通图的桥的数量,使用tarjan算法可以完成。

【题解代码】

解法1:tarjan算法求桥

#include<bits/stdc++.h>
using namespace std;
#define N 30005
int m, n, fa[N], dfn[N], low[N], ts, ans;
vector<int> edge[N];
void tarjan(int u)
{
	dfn[u] = low[u] = ++ts;
	for(int v : edge[u])
	{
		if(dfn[v] == 0)
		{
			fa[v] = u;
			tarjan(v);
			low[u] = min(low[u], low[v]);
			if(dfn[u] < low[v])
				ans++;
		}
		else if(v != fa[u])
			low[u] = min(low[u], dfn[v]);
	}
}
int main()
{
	int a, b;
	while(cin >> n >> m && n && m)//n是顶点数 m是边数  
	{
		memset(dfn, 0, sizeof(dfn));
		memset(fa, 0, sizeof(fa));
		ans = 0;
		for(int i = 1; i <= n; ++i)
			edge[i].clear();
		for(int i = 1; i <= m; ++i)
		{
			cin >> a >> b;
			edge[a].push_back(b);
			edge[b].push_back(a);
		}
		tarjan(1);//连通图只需要调用一次
		cout << ans << endl; 
	}
	return 0;
}

文章转载自:
http://cagy.elldm.cn
http://attenuator.elldm.cn
http://approximate.elldm.cn
http://animosity.elldm.cn
http://buea.elldm.cn
http://ceremonious.elldm.cn
http://acnode.elldm.cn
http://bndd.elldm.cn
http://asyllabic.elldm.cn
http://cattery.elldm.cn
http://announce.elldm.cn
http://chipewyan.elldm.cn
http://capacious.elldm.cn
http://cadential.elldm.cn
http://cannister.elldm.cn
http://anthozoic.elldm.cn
http://chilachap.elldm.cn
http://ausform.elldm.cn
http://abstruse.elldm.cn
http://cardioscope.elldm.cn
http://anamorphic.elldm.cn
http://boule.elldm.cn
http://algebraical.elldm.cn
http://alitalia.elldm.cn
http://alkalinity.elldm.cn
http://apologize.elldm.cn
http://cadmiferous.elldm.cn
http://aeolotropic.elldm.cn
http://apocalyptic.elldm.cn
http://aulic.elldm.cn
http://www.dtcms.com/a/109916.html

相关文章:

  • 胶铁一体化产品介绍
  • 什么是 SAML身份验证
  • 【DY】信息化集成化信号采集与处理系统;生物信号采集处理系统一体机
  • Qt实现登录界面(输入密码后过几秒,密码变为小黑点,眼睛改变密码明文,密文)
  • 电子电气架构 --- SOC设计流程及其集成开发环境
  • 企业知识库如何搭建?从零开始构建高效知识管理体系
  • 【Spring】Spring 注解解码:@RequestBody 与 @ResponseBody 的双向桥梁艺术
  • 2024年B会(Coling)——双重对比学习用于多模态对话情感识别
  • 数字人训练数据修正和查看 不需要GPU也能运行的DH_live-加载自己训练-
  • 注意力机制在大语言模型中的原理与实现总结
  • 【算法中的数学】分解质因数
  • 每天学一个 Linux 命令(11):cp
  • 【系统移植】(六)第三方驱动移植
  • MySQL:数据类型
  • 380_C++_[结合379]从连续内存地址中取出来的热力图图片data,转换为可视化的、带颜色的热力图像显示到界面(图像格式为RGBA)
  • Yapi部署指南:在 Linux 上 Yapi 教程
  • Linux Bash 脚本实战:自动监控域名证书过期并发送邮件告警
  • vue和angular实现飞机大战
  • 彩虹表攻击
  • 52.个人健康管理系统小程序(基于springbootvue)
  • Linux 高级命令与常见操作:文本处理、系统管理与网络调试
  • 红米AC2100-刷OpenWrt系统,安装zerotier教程
  • 7-6 混合类型数据格式化输入
  • 大数据(4)Hive数仓三大核心特性解剖:面向主题性、集成性、非易失性如何重塑企业数据价值?
  • PPT助手:一款集计时、远程控制与多屏切换于一身的PPT辅助工具
  • 【备忘】在Docker中安装宝塔面板,实现环境隔离,又能快速迁移服务器环境
  • 基于Flask的MBA考生成绩查询系统设计与实现
  • Java 可变参数(Varargs)使用指南
  • Vue实例中,setTimeout()不生效怎么解决
  • 联合类型|类型断言|交叉类型