基环树(pseudotree)入门

目录

  • 无向基环树
    • 找环,[题目](https://www.luogu.com.cn/problem/P8655)
      • 拓扑排序找环
      • 并查集找环
      • dfs找环
    • 内向基环树
      • [2876. 有向图访问计数](https://leetcode.cn/problems/count-visited-nodes-in-a-directed-graph/description/)
      • [2127. 参加会议的最多员工数](https://leetcode.cn/problems/maximum-employees-to-be-invited-to-a-meeting/description/)

无向基环树

找环,题目

给定一个图,N个点N条边,只有一个环,输出换上的点。

拓扑排序找环

#include <bits/stdc++.h>
using namespace std;// 点的编号从1开始
const int N = 100010;
int n;
vector<int> g[N];
vector<int> in, visit;void topologicalOrder() {queue<int> q;//把入度为1的点入队for (int i = 1; i <= n; i++) {if (in[i] == 1) q.push(i), visit[i] = 1;}while (q.size()) {int u = q.front();q.pop();for (int v: g[u]) {in[v]--;if (in[v] == 1) q.push(v), visit[v] = 1;}}
}void print() {for (int i = 1; i <= n; i++) if (!visit[i]) cout << i << " ";
}int main()
{cin >> n;in = vector<int>(n);visit = vector<int>(n);for (int i = 1; i <= n; i++) {int u, v;cin >> u >> v;g[u].push_back(v);g[v].push_back(u);in[u]++;in[v]++;}topologicalOrder();print();return 0;
}

并查集找环

#include <bits/stdc++.h>
using namespace std;// 并查集模板
struct DSU {std::vector<int> f, siz;DSU() {}DSU(int n) {init(n);}void init(int n) {f.resize(n);std::iota(f.begin(), f.end(), 0);siz.assign(n, 1);}int find(int x) {while (x != f[x]) {x = f[x] = f[f[x]];}return x;}bool same(int x, int y) {return find(x) == find(y);}bool merge(int x, int y) {x = find(x);y = find(y);if (x == y) {return false;}siz[x] += siz[y];f[y] = x;return true;}int size(int x) {return siz[find(x)];}
};// 点的编号从1开始
const int N = 100010;
int n;
vector<int> g[N];
vector<int> path;void findRing(int pre, int u, int v, int index) {path[index] = u;if (u == v) {sort(path.begin(), path.begin() + index + 1);for (int i = 0; i <= index; i++) cout << path[i] << " ";return ;}for (int j: g[u]) {if (j == pre) continue;findRing(u, j, v, index + 1);}
}int main()
{cin >> n;DSU dsu(n);path = vector<int>(n);for (int i = 1; i <= n; i++) {int u, v;cin >> u >> v;if (dsu.find(u) != dsu.find(v)) {// 两个点不联通g[u].push_back(v);g[v].push_back(u);dsu.merge(u, v);} else {// u和v已经联通了,那么我们在图中寻找从u到v的路径,这些都是环上的点findRing(-1, u, v, 0);}}return 0;
}

dfs找环

#include <bits/stdc++.h>
using namespace std;// 点的编号从1开始
const int N = 100010;
int n, idx;
vector<int> g[N];
vector<int> path, dfn, fa;void dfs(int u){if (dfn[u] != 0) return ;dfn[u]=++idx;for(int v: g[u]){if(v==fa[u]) continue;if(!dfn[v]) fa[v]=u,dfs(v);else {if(dfn[v]<dfn[u]) continue;path.push_back(v);for(; v != u; v=fa[v]) path.push_back(fa[v]);}} return;
}int main()
{cin >> n;idx = 0;dfn = vector<int>(n + 1);fa = vector<int>(n + 1);for (int i = 1; i <= n; i++) {int u, v;cin >> u >> v;g[u].push_back(v);g[v].push_back(u);}for (int i = 1; i <= n; i++) dfs(i);sort(path.begin(), path.end());for (int v: path) cout << v << " ";return 0;
}

内向基环树

每个点有且只有一个出边
内向基环树

2876. 有向图访问计数

class Solution {
public:vector<int> countVisitedNodes(vector<int>& g) {int n = g.size(); //节点的个数,节点的编号从0开始vector<vector<int>> rg(n); //反图vector<int> in(n);for (int x = 0; x < n; x++) {int y = g[x];// 一条从x到y的边: x -> yin[y]++;rg[y].push_back(x); //添加反向边到反图中}// 拓扑排序,剪掉g上所有的树枝queue<int> q;for (int i = 0; i < n; i++) if (in[i] == 0) q.push(i);while (q.size()) {int x = q.front();q.pop();int y = g[x];if (--in[y] == 0) q.push(y);}//答案数组, 表示的是从i点出发能访问到的节点数vector<int> ans(n, 0);function<void(int, int)> rdfs = [&](int x, int depth) {ans[x] = depth;// 以环上的点为根,通过反向边去搜树枝点// in[y]==0: 树枝点for (int y: rg[x]) if (in[y] == 0) rdfs(y, depth + 1);};for (int i = 0; i < n; i++) {// 0: 树枝点 -1: 基环上的点if (in[i] <= 0) continue;vector<int> ring;for (int x = i; ; x = g[x]) {in[x] = -1; // 基环上的点标记为-1,避免重复访问ring.push_back(x);if (g[x] == i) break; // 回到起点i了}for (int x: ring) rdfs(x, ring.size());}return ans;}
};

2127. 参加会议的最多员工数


class Solution {
public:int maximumInvitations(vector<int>& favorite) {int n = favorite.size();vector<int> in(n);// x -> yfor (int y: favorite) in[y]++;vector<vector<int>> rg(n); // 反图queue<int> q;for (int i = 0; i < n; i++) if (in[i] == 0) q.push(i);while (q.size()) {int x = q.front();q.pop();int y = favorite[x];rg[y].push_back(x);if (--in[y] == 0) q.push(y);}// 在反图上搜索树枝上最深的链function<int(int)> rdfs = [&](int x) -> int {int max_depth = 1;for (int son: rg[x]) max_depth = max(max_depth, rdfs(son) + 1);return max_depth;};int max_ring_size = 0, sum_chain_size = 0;for (int i = 0; i < n; i++) {if (in[i] == 0) continue;// 搜索基环上的点in[i] = 0; //标记,避免重复访问int ring_size = 1;for (int x = favorite[i]; x != i; x = favorite[x]) {in[x] = 0;ring_size++;}if (ring_size == 2) sum_chain_size += rdfs(i) + rdfs(favorite[i]);else max_ring_size = max(max_ring_size, ring_size);}return max(max_ring_size, sum_chain_size);}
};

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

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

相关文章

LeetCode701. Insert into a Binary Search Tree

文章目录 一、题目二、题解 一、题目 You are given the root node of a binary search tree (BST) and a value to insert into the tree. Return the root node of the BST after the insertion. It is guaranteed that the new value does not exist in the original BST. …

python表白弹框

# codinggbk import tkinter as tk import random# 创建主窗口并隐藏 root tk.Tk() root.attributes(-alpha, 0) # 设置主窗口为不可见# 表白内容 message "cnmsb"# 创建弹框函数 def create_popup():x random.randint(0, root.winfo_screenwidth()) # 随机生成…

Spring Boot 项目的常用注解与依赖

工具类 lombok 依赖 可以快速的为类提供 get&#xff0c;set&#xff0c;toString 等方法 <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional> </dependency> My…

取数游戏2(动态规划java)

取数游戏2 题目描述 给定两个长度为n的整数列A和B&#xff0c;每次你可以从A数列的左端或右端取走一个数。假设第i次取走的数为ax&#xff0c;则第i次取走的数的价值vibi⋅ax&#xff0c;现在希望你求出∑vi的最大值。 输入格式 第一行一个数T &#xff0c;表示有T 组数据。…

在CentOS 7上关闭SELinux

要在CentOS 7上关闭SELinux&#xff0c;可以按照以下步骤进行操作&#xff1a; 临时关闭SELinux&#xff08;不建议使用&#xff09;&#xff1a; setenforce 0但是这种方式只对当前启动有效&#xff0c;重启系统后会失效。 2. 永久关闭SELinux&#xff1a; vi /etc/selinux…

【C++】:模板的使用

目录 1、泛型编程 2、函数模板 2.1、函数模板概念 2.2、函数模板格式 2.3、函数模板的原理 2.4、函数模板的实例化 2.6、模板参数的匹配原则 3、类模板 3.1、 类模板的定义格式 3.2、 类模板的实例化 4、非类型模板参数 5、模板的特化 5.1、函数模板特化 5.2、类模…

公网访问全能知识库工具AFFINE,Notion的免费开源替代

文章目录 公网访问全能知识库工具AFFINE&#xff0c;Notion的免费开源替代品前言1. 使用Docker安装AFFINE2. 安装cpolar内网穿透工具3. 配置AFFINE公网访问地址4. 实现公网远程访问AFFINE 公网访问全能知识库工具AFFINE&#xff0c;Notion的免费开源替代品 前言 AFFiNE 是一个…

ChatGPT + Flutter快速开发多端聊天机器人App

在这个充满创新和机遇的时代&#xff0c;软件开发领域正在经历一场前所未有的变革。为了满足日益增长的用户需求和提升用户体验&#xff0c;我们引入了ChatGPT和Flutter两大技术&#xff0c;旨在打造一款功能强大、易于扩展的多端聊天机器人App。 ChatGPT&#xff1a;对话式人工…

04 后端增删改查【小白入门SpringBoot + Vue3】

项目笔记&#xff0c;教学视频来源于B站青戈 https://www.bilibili.com/video/BV1H14y1S7YV 保证前面的都功能都实现后&#xff0c;接着往下走。 查 分页 接下来&#xff0c;实现前端页面分页功能。 前端分页组件 打开elementplus官网&#xff0c;找到合适的分页组件&…

如何解决swagger-editor在线接口调试时的跨域问题

文章目录 一&#xff0c;序言二&#xff0c;问题重现1. 运行swagger-editor2. 运行接口服务3. 问题重现步骤 三&#xff0c;解决问题思路1. 去除浏览器安全限制2. 服务器接口统一处理3. 委托nginx转发 四&#xff0c;完整接口代码传送 一&#xff0c;序言 在 Docker 运行swagg…

持续集成部署-k8s-配置与存储-配置管理:ConfigMap 的热更新

ConfigMap 的热更新 1. 简介2. 新建 Pod3. 使用 edit 命令编辑修改4. 使用 replace 命令替换修改1. 简介 在 Kubernetes 中,ConfigMap 是用于存储非敏感配置数据的 API 对象,它可以被挂载到 Pod 中作为文件或环境变量。ConfigMap 的热更新指的是在不重启 Pod 的情况下,动态…

Linux 之 journalctl 查看系统与 kernel 日志

目录 1. Linux 之 journalctl 查看系统与 kernel 日志 1. Linux 之 journalctl 查看系统与 kernel 日志 1 概述 日志管理工具 journalctl 是 centos7 上专有的日志管理工具, 该工具是从 message 这个文件里读取信息。Systemd 统一管理所有 Unit 的启动日志。带来的好处就是, …

光敏传感器模块(YH-LDR)

目录 1. YH-LDR模块说明 1.1 简介 1.2 YH-LDR 模块的引脚说明 1.3 LDR 传感器工作原理与输出特性 2. 使用单片机系统控制 YH-LDR 模块 2.1 通用控制说明 1. YH-LDR模块说明 1.1 简介 YH-LDR 是野火设计的光强传感器&#xff0c;使用一个光敏电阻作为采集源&#x…

QString::fromLocal8Bit

QString::fromLocal8Bit QString::fromLocal8Bit 是 Qt 框架中的一个函数&#xff0c;用于将本地编码&#xff08;Local 8-bit&#xff09;的字符串转换为 QString 类型的字符串。下面对这个函数进行解释&#xff1a; QString QString::fromLocal8Bit(const char *str);str 是…

【C++】多线程的学习笔记(3)——白话文版(bushi

目录 前一篇内容&#xff08;mutex锁&#xff09; 前言 Condition Variable的简介 Condition Variable的使用方法 wait方法 wait for函数与wait until函数 notify函数 notify_one notify_all 注意 前一篇内容&#xff08;mutex锁&#xff09; 【C】多线程的学习笔记&…

Hive默认分割符、存储格式与数据压缩

目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…

pythongui实时闹钟

# codinggbk import tkinter as tk from time import strftime# 创建一个主窗口 root tk.Tk() root.title("实时闹钟")# 设置窗口的大小不可变 root.resizable(False, False)# 设置窗口始终保持在最上层 root.attributes(-topmost, True)# 更新时间的函数 def time(…

java游戏制作-拼图游戏

一.制作主界面 首先创建一个Java项目命名为puzzlegame。 再在src中创建一个包&#xff0c;用来制作主界面 代码&#xff1a; 结果&#xff1a; 二.设置界面 代码&#xff1a; 三.初始化界面 代码&#xff1a; 优 化代码&#xff1a; 结果&#xff1a; 四.添加图片 先在Java项…

mysql查询json字符串内容

参考文章&#xff1a;mysql json 基础查询_mysql json查询-CSDN博客 mysql查询json字符串内容 &#xff08;多层数组嵌套&#xff09; select id,nameJSON_EXTRACT(JSON_UNQUOTE(JSON_EXTRACT(JSON_UNQUOTE(config_json), $.baseInfo)), $.template_list[*].sms_content) s…

Golang Context 的使用指南

Golang Context 的使用指南 1. 什么是 Context 在 Golang 中&#xff0c;Context 是一个用于跨 goroutine 传递数据、取消任务以及超时控制的标准库。它提供了一种从父 goroutine 向子 goroutine 传递请求或控制信息的机制&#xff0c;可以有效地管理和控制 goroutine 的生命…