洛谷 P3225 矿场搭建 —— tarjan + 点双分析

2023-11-02 10:32

本文主要是介绍洛谷 P3225 矿场搭建 —— tarjan + 点双分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:点我啊╭(╯^╰)╮

题目大意:

    无向图,任意一个矿点坍塌以后,其他所有矿点都必须有路到救援出口
    求最少设置几个救援出口,设置最少出口的方案数

解题思路:

    这道题确实有点难。。。

    对于一个点双联通分量,大小为 K K K ,若没有割点与它相连
    说明它与世隔绝,则在这个联通分量里必须设置两个救援出口
    因为只设置一个点可能坍塌,方案数是 C ( k , 2 ) C(k, 2) C(k,2)

    对于一个点双联通分量,若有一个割点与它相连
    只需要设置一个救援出口即可,因为即使这个点坍塌了,其他点也可以通过这个割点到其他分量里
    因此方案数是 k k k

    对于一个点双联通分量,若有 ≥ ≥ 两个割点与它相连
    则不需要设置出口,无论哪个割点坍塌了,都有另一个割点连通到外部
    因此方案数是 0 0 0

    那么会不会出现所有联通分量都有两个以上的割点与它相连呢??
    显示是不存在的,聪明的孩子都知道。
    这样一看好像这题很简单,是错觉吗

#include<bits/stdc++.h>
#define rint register int
#define deb(x) cerr<<#x<<" = "<<(x)<<'\n';
using namespace std;
typedef long long ll;
typedef pair <int,int> pii;
const int maxn = 505;
int n, m, cnt, cntc;
int dfn[maxn], low[maxn], vis[maxn];
int tot, color, iscut[maxn], cas;
ll ans1, ans2;
vector <int> g[maxn];void tarjan(int u, int fa){dfn[u] = low[u] = ++tot;int child = 0;for(auto v : g[u]){if(v == fa) continue;if(!dfn[v]) {child++;tarjan(v, u);low[u] = min(low[u], low[v]);if(low[v] >= dfn[u]) iscut[u] = 1;} else low[u] = min(low[u], dfn[v]);}if(!fa && child==1) iscut[u] = 0;
}void dfs(int u, int color){vis[u] = color, cnt++;for(auto v : g[u]){if(iscut[v] && color!=vis[v]) cntc++, vis[v] = color;if(!vis[v]) dfs(v, color);}
}signed main() {while(~scanf("%d", &m) && m){memset(dfn, 0, sizeof(dfn));memset(low, 0, sizeof(low));memset(vis, 0, sizeof(vis));memset(iscut, 0, sizeof(iscut));tot = color = ans1 = n = 0, ans2 = 1;for(int i=0; i<maxn; i++) g[i].clear();for(int i=1, u, v; i<=m; i++) {scanf("%d%d", &u, &v);g[u].push_back(v);g[v].push_back(u);n = max(n, max(u, v));}for(int i=1; i<=n; i++)if(!dfn[i]) tarjan(i, 0);for(int i=1; i<=n; i++){if(iscut[i] || vis[i]) continue;color++, cnt = cntc = 0;dfs(i, color);if(cntc == 0) ans1 += 2, ans2 *= cnt * (cnt - 1) / 2;else if(cntc == 1) ans1++, ans2 *= cnt;}printf("Case %d: %lld %lld\n", ++cas, ans1, ans2);}
}

这篇关于洛谷 P3225 矿场搭建 —— tarjan + 点双分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/329996

相关文章

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud

线性因子模型 - 独立分量分析(ICA)篇

序言 线性因子模型是数据分析与机器学习中的一类重要模型,它们通过引入潜变量( latent variables \text{latent variables} latent variables)来更好地表征数据。其中,独立分量分析( ICA \text{ICA} ICA)作为线性因子模型的一种,以其独特的视角和广泛的应用领域而备受关注。 ICA \text{ICA} ICA旨在将观察到的复杂信号

【软考】希尔排序算法分析

目录 1. c代码2. 运行截图3. 运行解析 1. c代码 #include <stdio.h>#include <stdlib.h> void shellSort(int data[], int n){// 划分的数组,例如8个数则为[4, 2, 1]int *delta;int k;// i控制delta的轮次int i;// 临时变量,换值int temp;in

三相直流无刷电机(BLDC)控制算法实现:BLDC有感启动算法思路分析

一枚从事路径规划算法、运动控制算法、BLDC/FOC电机控制算法、工控、物联网工程师,爱吃土豆。如有需要技术交流或者需要方案帮助、需求:以下为联系方式—V 方案1:通过霍尔传感器IO中断触发换相 1.1 整体执行思路 霍尔传感器U、V、W三相通过IO+EXIT中断的方式进行霍尔传感器数据的读取。将IO口配置为上升沿+下降沿中断触发的方式。当霍尔传感器信号发生发生信号的变化就会触发中断在中断