浅说图论基础
引入
在学最短路算法之前,我们要先搞清楚另外一个事情,什么是图,我们又可以基于图做那些事情。
图不同于树,它是一种更加复杂的数据结构,相比较于树或者数组(线性表)而言,图的关联性显然更加强。比如说,在树中,一个点只有可能和他的父亲节点和他的儿子节点有直接的联系,但是在图中,任意两个点之间都有可能会有联系,也就是说节点之间的连通性是任意的。
同时,图也是包含了许多东西的,笼统的来说,图是包含树的,但是又不完全包含,因为图是允许有空边的(也就是说可以没有边),但是不能有空点的(也就是说至少也要有一个点),但是树是可以有空树的,线性表也是可以有空表的。
图可以干很多事,比如说我们这节课要学的最短路,除此之外,还有什么最小生成树啊,拓扑排序啊,这些都是图论,甚至于可以将一些不等式的求解或者是生活的一些实际问题放到图上来做,也就是我们后续也要讲的差分约束。
图论基础
图的存储
我们可以用两种方式来存储图,一种是邻接表,一种是链式前向星。不过我们最长用的还是邻接表,链式前向星其实没有太大的用处。所以说,我们还是使用邻接表吧,这个比较简单。
vector<int> mp[1000];
mp[u].push_back(v);
图的遍历
图还是和树一样,有深度优先遍历,也有广度优先遍历,其实实现的方法和之前的差不多,所以说可以直接写。
图的深度优先遍历
#include<bits/stdc++.h>
using namespace std;
const int INF=100000+10;
vector<int> mp[INF];
int used[INF];
int n,m;
void dfs(int x,int fa){used[x]=1;cout<<x<<" ";for (int i=0;i<mp[x].size();i++){if (used[mp[x][i]]==0){dfs(mp[x][i],x);}}return;
}
int main(){cin>>n>>m;for (int i=1;i<=m;i++){int u,v;cin>>u>>v;mp[u].push_back(v);mp[v].push_back(u);}dfs(1,-1);return 0;
}
图的广度优先遍历
#include<bits/stdc++.h>
using namespace std;
const int INF=100000+10;
vector<int> mp[INF];
int used[INF];
int n,m;
void bfs(int x){queue<int> q;q.push(x);used[x]=1;while (!q.empty()){x=q.front();cout<<x<<" ";q.pop();for (int i=0;i<mp[x].size();i++){if (used[mp[x][i]]==0){q.push(mp[x][i]);used[mp[x][i]]=1;}}}
}
int main(){cin>>n>>m;for (int i=1;i<=m;i++){int u,v;cin>>u>>v;mp[u].push_back(v);mp[v].push_back(u);}bfs(1);return 0;
}
图的联通性
对于一个图而言,如果任意两个点之间可以互相到达,那么就说明这个图是联通的。那么我们可以怎么检测一个图是否联通呢?其实很简单,我们直接从一个点出发,如果说可以到达所有点,那么这个图就一定是联通的,这也是上述定义的推论。下面以无向图为例子写一个代码:
#include<bits/stdc++.h>
using namespace std;
const int INF=100000+10;
vector<int> mp[INF];
int used[INF];
void dfs(int x){for (int i=0;i<mp[x].size();i++){if (used[mp[x][i]]==0){used[mp[x][i]]=1;dfs(mp[x][i]);}}
}
int main(){int n,m;cin>>n>>m;for (int i=1;i<=m;i++){int u,v;cin>>u>>v;mp[u].push_back(v);mp[v].push_back(u);}used[1]=1;dfs(1);for (int i=1;i<=n;i++){if (used[i]==0){cout<<"No";return 0;}}cout<<"Yes";return 0;
}
例题
A163 传递闭包
题目描述
给出一张 n n n 个节点的有向图,求任意两个节点之间是否可达。
输入格式
从标准输入读入数据。
第一行输入一个正整数 ( n ≤ 2000 ) (n≤2000) (n≤2000)。
接下来 n n n 行,每行输入一个长度为 n n n 的 01 串,构成一个 n × n n×n n×n 的 01 矩阵 A A A,其中 A i j = 1 A_{ij} =1 Aij=1 代表 i i i 到 j j j 有边,否则代表没有边。
输出格式
输出到标准输出。
输出 n n n 行,每行输出一个长度为 n n n 的 01 串,构成一个 n × n n×n n×n 的 01 矩阵 B B B,其中 B i j = 1 B_{ij} =1 Bij=1 代表 i i i 到 j j j 可到达,否则代表不可到达。
样例1输入
4
0100
0110
1000
0101
样例1输出
1110
1110
1110
1111
分析——题解
其实这道题就是有向图的联通性问题,不过根据题目中所述,我们是要知道每个点可以到达哪个点的,所以说,我们可以从每个点出发,去看那些点合适,这样就对了,不过要注意一下,记得清空标记数组,否则十年OI一场空。
#include<bits/stdc++.h>
using namespace std;
int used[2100];
vector<int> mp[2100];void dfs(int x){used[x]=1;for (int i=0;i<mp[x].size();i++){if (used[mp[x][i]]==0){used[mp[x][i]]=1;dfs(mp[x][i]);}}
}
int main(){int n;cin>>n;for (int i=1;i<=n;i++){for (int j=1;j<=n;j++){char ch;cin>>ch;if (ch=='1')mp[i].push_back(j);}}for (int i=1;i<=n;i++){dfs(i);for (int i=1;i<=n;i++){cout<<used[i];}cout<<endl;memset(used,0,sizeof(used));}return 0;
}
相关文章:
浅说图论基础
引入 在学最短路算法之前,我们要先搞清楚另外一个事情,什么是图,我们又可以基于图做那些事情。 图不同于树,它是一种更加复杂的数据结构,相比较于树或者数组(线性表)而言,图的关联…...
DeepSeek【部署 03】客户端应用ChatBox、AnythingLLM及OpenWebUI部署使用详细步骤
DeepSeek客户端应用 1.ChatBox2.AnythingLLM3.OpenWebUI4.总结 客户端软件提供可视化的模型及参数配置,人性化的对话窗口及文件上传功能,大大降低了大模型的使用门槛。 1.ChatBox Chatbox AI 是一款 AI 客户端应用和智能助手,支持众多先进的…...
工作学习笔记:HarmonyOS 核心术语速查表(v14 实战版)
作为在 HarmonyOS 开发一线摸爬滚打的工程师,笔者在 v14 版本迭代中整理了这份带血的实战术语表。 一、架构基础术语速查 A 系列术语 术语官方定义笔者解读(v14 实战版)开发陷阱 & 解决方案abc 文件ArkCompiler 生成的字节码文件打包时…...
mapbox进阶,模仿百度,简单实现室内楼层切换
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️fill-extrusion三维填充图层样式1.4 ☘…...
发行基础:热销商品榜单
转载自官方文件 ------------------ 热销商品榜单 Steam 在整个商店范围内有各种热销商品榜单,最醒目的莫过于 Steam 主页上的榜单了。 您也可以在浏览单个标签、主题、类型时找到针对某个游戏类别的热销商品榜单。 主页热销商品榜单 该榜单出现在 Steam 主页上…...
Android Studio 一直 Loading devices
https://stackoverflow.com/questions/71013971/android-studio-stuck-on-loading-devices...
【时间序列】因果推断:从时序数据中探寻“因”与“果”
在日常生活中,我们经常听到这样的问题:“为什么股票价格会突然下跌?”、“天气变化是否会影响销售额?”这些问题背后,其实都在试图寻找一种因果关系。然而,在时间序列数据中,探寻因果关系并不像…...
联核科技AGV无人叉车的应用场景有哪些?
联核科技AGV无人自动叉车在多个应用场景中均展现出卓越的性能和广泛的应用价值。下面是针对每个应用场景的简要概括、适用车型及其功能的详细介绍联核科技官网-AGV叉车十大品牌-无人叉车厂家-自动化叉车-智能搬运码垛机器人-智能叉车系统解决方案专家 上存下拣 上层四向车立体…...
多模态知识图谱融合
1.Knowledge Graphs Meet Multi-Modal Learning: A Comprehensive Survey 1.1多模态实体对齐 1.2多模态实体链接 研究进展&#...
c++实现最大公因数和最小公倍数
最大公因数和最小公倍数的介绍 读这篇文章,请你先对最大公因数以及最小公倍数进行了解: 最大公因数(英文名:gcd) 定义:最大公因数,也称最大公约数,指两个或多个整数共有约数&…...
利用optisystem软件仿真半导体激光器的P-I特性曲线
利用optisystem软件仿真半导体激光器的P-I特性曲线。得到的图形遵循在超过阈值电流之后,输出光功率与电流成线性关系规律。 资源文件列表 FiberP-I.m , 1881 PCMcode.m , 830 PRseries.m , 140 photo_detect.m , 638...
华为:Wireshark的OSPF抓包分析过程
一、OSPF 的5包7状态 5个数据包 1.Hello:发现、建立邻居(邻接)关系、维持、周期保活;存在全网唯一的RID,使用IP地址表示 2.DBD:本地的数据库的目录(摘要),LSDB的目录&…...
RangeError: Invalid array length
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 🍚 蓝桥云课签约作者、…...
django各种mixin用法
在 Django 中,Mixin 是一种用于扩展类功能的设计模式。通过 Mixin,可以在不修改原有类的情况下,为其添加新的方法或属性。Django 中的 Mixin 广泛应用于视图(View)、表单(Form)、模型(Model)等组件中。以下是 Django 中常见 Mixin 的用法和示例: 一、视图(View)中的…...
【leetcode hot 100 206】反转链表
解法一:(头插法)在遍历链表时,将当前节点的 next 指针改为指向前一个节点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val)…...
OpenCV视频解码实战指南
硬核解析OpenCV视频处理底层原理,从零实现高效视频解码流水线!附赠FFmpeg调优参数和异常帧处理方案,建议收藏备用。 📺 视频解码核心原理 视频容器 vs 编码格式 类型常见格式特点容器格式MP4/MKV/AVI/MOV存储封装格式࿰…...
USB流量分析总结(实战[NISACTF 2022] 破损的flag)
一、USB流量分析 USB协议的数据部分在 Leftover Capture Data 域之中,可以用tshark命令将leftover capture data 数据单独提取出来,利用命令如下: tshark -r 1.pcapng -T fields -e usb.capdata > usbdata.txt tshark -r 1.pcapng -T fields -e usb…...
CentOS7离线部署安装docker和docker-compose
CentOS7离线部署安装docker和docker-compose 安装包准备 docker下载地址、docker-compose下载地址 docker和docker-compose版本对应关系 注:本次安装部署选择的版本是 docker:docker-28.0.1.tgzdocker-compose:docker-compose-linux-x86_6…...
【第21节】C++设计模式(行为模式)-Chain of Responsibility(责任链)模式
一、问题背景 在 VC/MFC 开发中,消息处理机制是核心部分之一。VC 是基于消息和事件驱动的框架,消息的处理流程通常是通过链式传递的方式进行的。例如,一个 WM_COMMAND 消息的处理流程可能如下: (1)MDI 主窗…...
vue3页面html导出word文档
一、第三方包下载 使用npm下载以下插件: npm install jszip-utils docxtemplater pizzip file-saver docxtemplater-image-module-free 二、总页面组件代码 <template> <summaryDetails :securityId"securityId" :symbol"symbol" …...
防火墙带宽管理实验
一、实验拓扑图 二、实验要求 需求一: 企业组织架构中存在部门A ,部门 A 中存在销售组 1 和研发组 2 销售部门---> 业务 Email 、 ERP 服务 可以对部门A 中的销售组进行带宽资源细分,保证销售员工的业务服务流量正常转…...
高颜值多端适用软件:兼具屏保功能,PC 端登录可用
软件介绍 FliTik是一款翻页式时钟软件,外观颜值颇高,支持Windows和TV端。 这款软件最大的亮点之一,就是它采用了极为吸睛的翻页式设计。当你第一眼看到它的界面时,相信一定会和我一样,被它超高的颜值所惊艳到。简洁大方的布局&a…...
基于Fluent和深度学习算法驱动的流体力学计算与应用
流体力学基础 一、流体力学基础理论与编程实战 1、流体力学的主要内容 2、不可压缩流体力学的基本方程 3、Navier–Stokes方程的数值求解介绍 4、有限体积法与有限差分法介绍 案例实践: 1、Matlab编程实现有限差分(案例教学) 2、使用深度学习…...
uniapp使用蓝牙,usb,局域网,打印机打印
使用流程(支持安卓和iOS) 引入SDK 引入原生插件包地址如下 https://github.com/oldfive20250214/UniPrinterDemo 连接设备 安卓支持经典蓝牙、ble蓝牙、usb、局域网(参考API) iOS支持ble蓝牙、局域网(参考API&…...
【计算机网络】Socket
Socket 是网络通信的核心技术之一,充当应用程序与网络协议栈之间的接口。 1. Socket 定义 Socket(套接字)是操作系统提供的 网络通信抽象层,允许应用程序通过标准接口(如 TCP/IP 或 UDP)进行数据传输。它…...
YOLO11改进-模块-引入多尺度小波池化变压器MWPT 通过结合小波变换、多尺度池化以及门控机制等技术解决多尺度、小目标、边缘模糊等问题
手势识别在人机交互等领域应用广泛,但面临手部姿态多变、环境因素干扰等挑战。深度学习发展促使基于注意力的模型兴起,Transformer 在自然语言处理和计算机视觉诸多任务表现出色,也被用于手势识别。不过,传统 Transformer 处理视觉…...
HTML + CSS 题目
1.说说你对盒子模型的理解? 一、是什么 对一个文档进行布局的时候,浏览器渲染引擎会根据标准之一的css基础盒模型,将所有元素表示为一个个矩形的盒子。 一个盒子由四个部分组成: content,padding,border,margin 下…...
clickhouse的优缺点
《ClickHouse的优缺点及成功案例分析》 当我们谈论数据库技术时,ClickHouse无疑是一个引人注目的名字。它是一种专为在线分析处理(OLAP)设计的列式数据库管理系统(DBMS),由俄罗斯的Yandex公司开发。随着大…...
kettle工具使用从入门到精通(一)
安装 可以从链接: 官网(下载链接在Pentaho.pdf文件里)或者网络上查找对应的版本安装 Kettle (PDI) 版本与 JDK 版本对应关系 Kettle (PDI) 版本支持的 JDK 版本备注PDI 9.x 及以上JDK 11 或更高版本推荐使用 OpenJDK 或 Oracle JDK 11。PDI 8.xJDK 8 …...
引领变革!北京爱悦诗科技有限公司荣获“GAS消费电子科创奖-产品创新奖”!
在2025年“GAS消费电子科创奖”评选中,北京爱悦诗科技有限公司提交的“aigo爱国者GS06”,在技术创新性、设计创新性、工艺创新性、智能化创新性及原创性五大维度均获得评委的高度认可,荣获“产品创新奖”。 这一奖项不仅是对爱悦诗在消费电子…...
【探商宝】大数据企业销售线索平台:销售型公司的战略转型引擎
一、市场现状与销售型公司的核心痛点 在数字经济高速发展的2025年,全球企业获客成本较五年前增长超过300%,而B2B销售线索的平均转化率仍徘徊在15%-20%之间。这一矛盾背后,折射出传统销售模式的三重困境: 数据孤岛导致决策滞后…...
机器学习在地图制图学中的应用
原文链接:https://www.tandfonline.com/doi/full/10.1080/15230406.2023.2295948#abstract CSDN/2025/Machine learning in cartography.pdf at main keykeywu2048/CSDN GitHub 核心内容 本文是《制图学与地理信息科学》特刊的扩展评论,系统探讨了机…...
Python Flask框架学习汇编
1、入门级: 《Python Flask Web 框架入门》 这篇博文条理清晰,由简入繁,案例丰富,分十五节详细讲解了Flask框架,强烈推荐! 《python的简单web框架flask【附例子】》 讲解的特别清楚,每一步都…...
C++20的简写函数模板
文章目录 简写函数模板的语法示例代码优点 C20引入了简写函数模板(Abbreviated Function Template),这是一种更简洁的函数模板声明方式,允许使用 auto或带有约束的 auto来代替显式的模板参数声明。 简写函数模板的语法 当在函数…...
【Python 数据结构 9.树】
我装作漠视一切,其实我在乎的太多,但我知道抓得越紧越容易失去 —— 25.3.6 一、树的基本概念 1.树的定义 树是n个结点的有限集合,n0时为空树。当n大于0的时候,满足如下两个条件: ① 有且仅有一个特定的结点ÿ…...
美团校招实习笔试历年真题与内推
美团第一场笔试时间在本周六晚19:00开启 想知道笔试考什么?来刷刷历年真题 👉点击https://my5353.com/Bo1c1历年真题开刷! −−−−−−−−−−−−−−−−−−−−−− 1⃣【26届转正实习】70%转正留用,提前锁定正式offer&…...
redis的淘汰策略
Redis 的淘汰策略(Eviction Policy)是指当 Redis 内存不足时,如何选择删除哪些数据来腾出空间。以下是 Redis 支持的几种淘汰策略,用通俗的话解释它们的特点: 1. noeviction(不淘汰) 特点&#…...
Linux中的TCP编程接口基本使用
TCP编程接口基本使用 本篇介绍 在UDP编程接口基本使用已经介绍过UDP编程相关的接口,本篇开始介绍TCP编程相关的接口。有了UDP编程的基础,理解TCP相关的接口会更加容易,下面将按照两个方向使用TCP编程接口: 基本使用TCP编程接口…...
javaweb:Maven、SpringBoot快速入门、HTTP协议
Maven Maven作用 介绍 Maven的坐标 依赖配置 依赖传递 排除依赖 依赖范围 生命周期 clean:清除编译文件 compile:生成编译文件 test:执行所有的单元测试方法(在pom.xml引入Junit单元测试依赖) package:…...
macOS常用网络管理配置命令
目录 **1. ifconfig:查看和配置网络接口****2. networksetup:管理系统网络配置****3. ping:测试网络连通性****4. traceroute:跟踪数据包路径****5. nslookup/dig:DNS 查询****6. netstat:查看网络连接和统…...
IntelliJ IDEA 中配置 Groovy
在 IntelliJ IDEA 中配置 Groovy 环境可以分为以下几个步骤 1. 安装 Groovy 插件 步骤: 打开 IntelliJ IDEA,进入菜单栏:File → Settings(Windows/Linux)或 IntelliJ IDEA → Preferences(Mac࿰…...
如何实现区域灰质体积、皮层厚度、低频振幅等影像学特征的病例-对照分析差异分析
在神经影像学研究中,病例-对照分析(case-control analysis)是一种常见的方法,用于比较患者组(cases)与健康对照组(controls)在脑结构和功能上的差异。本文介绍如何利用病例-对照分析…...
WordPress报502错误问题解决-php-fpm-84.service loaded failed failed LSB: starts php-fpm
文章目录 问题描述问题排查问题解决 问题描述 服务器环境: php:8.4MySQL:8.0Nginx:1.26.2 在访问站点时,一直报502,而两天前还能正常访问。 问题排查 导致502的问题很多,比如站点访问量太大…...
2025上软考下周开启报名!附报考流程和常见问题解答
报名时间 :3月10日开始报名(以当地报名时间为准) 考试时间 :2025年5月24日~27日(具体时间以准考证为准) 报名网址 :中国计算机技术职业资格网(https://bm.ruankao.org.cn/sign/welcome) 目前已…...
Process-based Self-Rewarding Language Models 论文简介
基于过程的自奖励语言模型:LLM优化的新范式 引言 大型语言模型(LLM)在多种任务中展现出了强大的能力,尤其是在使用人工标注的偏好数据进行训练时。然而,传统的自奖励范式在数学推理任务中存在局限性,甚至…...
Kotlin字符串操作在Android开发中的应用示例
Kotlin字符串操作在Android开发中的应用示例 引言 在Android开发中,Kotlin已经成为主流的编程语言,它提供了许多便捷的字符串操作功能。本文将结合一个具体的Kotlin示例程序,详细介绍Kotlin中字符串的创建、格式化和使用方法。 示例代码 以…...
自律 linux 第 36 天
昨天学习IO多路复用的时候使用的是select函数接口, select需要在应用层建立一个放套接字的表,然后传入内核中,再又内核将响应的套接字表传回应用层,这样耗费时间和资源,而且这个表只能存放最多1024个套接字,…...
《从零开始构建视频同步字幕播放软件》
《从零开始构建视频同步字幕播放软件》 字幕软件:数字时代的 “语言桥梁” 在全球化进程不断加速的今天,我们正处于一个信息爆炸且多元文化交融的时代。电影、剧集、公开课、短视频等各类视频内容,跨越了地域与国界的限制,在互联…...
VirtualBox虚拟机安装Mac OS启动后的系统设置
VirtualBox虚拟机安装Mac OS一直没装成功,本来想要放弃的,后来想着再试一次,于是在关机的情况,执行那几句设置: cd "E:\Program Files\Oracle\VirtualBox\" VBoxManage.exe modifyvm "MacOS" --c…...
JDK ZOOKEEPER KAFKA安装
JDK17下载安装 mkdir -p /usr/local/develop cd /usr/local/develop 将下载的包上传服务器指定路径 解压文件 tar -zxvf jdk-17.0.14_linux-x64_bin.tar.gz -C /usr/local/develop/ 修改文件夹名 mv /usr/local/develop/jdk-17.0.14 /usr/local/develop/java17 配置环境变量…...