- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
无向图是由顶点和边组成的图,其中边没有方向性,即连接两个顶点的边可以从任意一个顶点出发。关联矩阵和邻接矩阵是两种常用的表示无向图的方法。' m$ C F/ C5 p! |8 V) O; @
, n# I1 W6 m+ m* |& t关联矩阵是一个二维矩阵,其中行代表顶点,列代表边,矩阵中的元素表示顶点与边的关系,通常用1表示顶点与边相连,0表示不相连。
5 O7 g3 U- g# F' A/ e6 D5 N7 o$ L( A' G6 g9 y0 A! F2 I+ I, V% l
邻接矩阵是一个二维矩阵,其中行和列都代表顶点,矩阵中的元素表示两个顶点之间是否有边相连,通常用1表示相连,0表示不相连。/ l# u) |: v2 G3 ~& K( a
3 c; Y$ F3 O, B: p, M关联矩阵和邻接矩阵可以通过相互转换来表示同一个无向图。转换算法如下:% k1 s9 j; m/ G8 k/ q
- Y( x' ]% u- S
1. 从关联矩阵到邻接矩阵的转换:4 a% [) h4 J) w' g1 i7 G; _
- 创建一个n x n的全零矩阵,其中n为顶点的个数。
) ^6 w$ U! s6 K8 L% w2 r0 l0 r - 遍历关联矩阵的每一列,找到与该边相关的两个顶点,将这两个顶点在邻接矩阵中的位置设为1。
# Q& W' N ~# @
( Z/ s) a- q Z* s2. 从邻接矩阵到关联矩阵的转换:* e, J2 c% g8 R3 V+ L3 h. k
- 创建一个n x m的全零矩阵,其中n为顶点的个数,m为边的个数。& c3 ^0 i& |7 _* U+ {2 N, P( }
- 遍历邻接矩阵的上三角部分(因为无向图的邻接矩阵是对称的),找到值为1的位置,表示两个顶点相连。# W# e% |. x3 a) \7 M* m/ U
- 将这两个顶点所对应的边在关联矩阵中的位置设为1。# M1 \6 o9 b" R, V) G. L% f0 U; A3 |
- y- ]( H+ X9 J3 r$ f
通过这样的转换算法,我们可以方便地在关联矩阵和邻接矩阵之间进行转换,从而更方便地对无向图进行分析和处理。
2 F7 G5 k0 a; d2 c) c5 z接下来给大家分享一下代码
: f) Q' b! H6 N% X7 s1 I/ K
. L& G# j9 N% [8 C0 N9 k# [1 t
6 h7 r" p1 f& m |
zan
|