数据结构–图的基本操作
使用的存储模式:
data:image/s3,"s3://crabby-images/a40c3/a40c3faf96008c20add7818350cc0c8d1e2f88c9" alt=""
图的基本操作:
• Adjacent(G,x,y):判断图G是否存在边<x, y>或(x, y)。
• Neighbors(G,x):列出图G中与结点x邻接的边。
• InsertVertex(G,x):在图G中插入顶点x。
• DeleteVertex(G,x):从图G中删除顶点x。
• AddEdge(G,x,y):若无向边(x, y)或有向边<x, y>不存在,则向图G中添加该边。
• RemoveEdge(G,x,y):若无向边(x, y)或有向边<x, y>存在,则从图G中删除该边。
• FirstNeighbor(G,x):求图G中顶点x的第一个邻接点,若有则返回顶点号。若x没有邻接点
或图中不存在x,则返回-1。
• NextNeighbor(G,x,y):假设图G中顶点y是顶点x的一个邻接点,返回除y之外顶点x的下一
个邻接点的顶点号,若y是x的最后一个邻接点,则返回-1。
• Get_edge_value(G,x,y):获取图G中边(x, y)或<x, y>对应的权值。
• Set_edge_value(G,x,y,v):设置图G中边(x, y)或<x, y>对应的权值为v。
图的基本操作
Adjacent(G,x,y)
判断图G是否存在边<x, y>或(x, y)。
有向图:
data:image/s3,"s3://crabby-images/e41e8/e41e88f809b937b2188725a5c0ee1cc399ffa2fe" alt=""
data:image/s3,"s3://crabby-images/56c00/56c0079ce5b7abb853959cccf8cca92aad6542f4" alt=""
无向图:
data:image/s3,"s3://crabby-images/20925/20925f893875658cfc1f1a1b282342c650bef596" alt=""
data:image/s3,"s3://crabby-images/68bfd/68bfd36a28a7bdb6f1aee429cf05e6d4c03d6a96" alt=""
Neighbors(G,x)
列出图G中与结点x邻接的边。
无向图:
data:image/s3,"s3://crabby-images/e6df5/e6df5821a9f8025397ca357c9de940231879f202" alt=""
data:image/s3,"s3://crabby-images/0107f/0107fa8b0993736d0667afa3e753d14799b1c8b9" alt=""
有向图:
data:image/s3,"s3://crabby-images/ca144/ca1442f988c71724b2bf27f9c84baa530138a89e" alt=""
data:image/s3,"s3://crabby-images/d48cc/d48ccccf59e174e70acef95896b9944afa47e404" alt=""
InsertVertex(G,x)
在图G中插入顶点x。
无向图:
data:image/s3,"s3://crabby-images/e5cdf/e5cdfcf55ae53beec11e750166975e6dfd1079e2" alt=""
DeleteVertex(G,x)
从图G中删除顶点x。
无向图:
data:image/s3,"s3://crabby-images/b99d9/b99d971caffb9f2653713716e9b5666216abb34a" alt=""
有向图:
data:image/s3,"s3://crabby-images/26d32/26d32b834dde32d926d0da6cdbc9c9f7d344af38" alt=""
AddEdge(G,x,y)
若无向边(x, y)或有向边<x, y>不存在,则向图G中添加该边。
无向图:
data:image/s3,"s3://crabby-images/6f96c/6f96c52c946491675c664ac2a9e1cce3bcbfccf3" alt=""
RemoveEdge(G,x,y)
若无向边(x, y)或有向边<x, y>存在,则从图G中删除该边。
无向图:
data:image/s3,"s3://crabby-images/322c1/322c1474768f822d9b145f1c3299d63b4d133fee" alt=""
FirstNeighbor(G,x)
求图G中顶点x的第一个邻接点,若有则返回顶点号。若x没有邻接点或图中不存在x,则返回-1。
无向图:
data:image/s3,"s3://crabby-images/9fb41/9fb412c0deca7a031cb55bb2499ec2e73a7748cb" alt=""
有向图:
data:image/s3,"s3://crabby-images/f5f89/f5f89ba64cae1154c1ab859c76eab36545be6391" alt=""
NextNeighbor(G,x,y)
假设图G中顶点y是顶点x的一个邻接点,返回除y之外顶点x的下一个邻接点的顶点号,若y是x的最后一个邻接点,则返回-1。
无向图:
data:image/s3,"s3://crabby-images/4b6d8/4b6d82652be37bf0427012a6e8590f5099376f68" alt=""
Get_edge_value(G,x,y)
获取图G中边(x, y)或<x, y>对应的权值。
Set_edge_value(G,x,y,v)
设置图G中边(x, y)或<x, y>对应的权值v。
Adjacent(G,x,y)
判断图G是否存在边<x, y>或(x, y)。
无向图:
data:image/s3,"s3://crabby-images/a610c/a610c6f2c4a94e189d04a5962e8067749db51a49" alt=""
知识回顾与重要考点
• Adjacent(G,x,y):判断图G是否存在边<x, y>或(x, y)。
• Neighbors(G,x):列出图G中与结点x邻接的边。
• InsertVertex(G,x):在图G中插入顶点x。
• DeleteVertex(G,x):从图G中删除顶点x。
• AddEdge(G,x,y):若无向边(x, y)或有向边<x, y>不存在,则向图G中添加该边。
• RemoveEdge(G,x,y):若无向边(x, y)或有向边<x, y>存在,则从图G中删除该边。
•
F
i
r
s
t
N
e
i
g
h
b
o
r
(
G
,
x
)
\color{red}FirstNeighbor(G,x)
FirstNeighbor(G,x):求图G中顶点x的第一个邻接点,若有则返回顶点号。若x没有邻接点
或图中不存在x,则返回-1。
•
N
e
x
t
N
e
i
g
h
b
o
r
(
G
,
x
,
y
)
\color{red}NextNeighbor(G,x,y)
NextNeighbor(G,x,y):假设图G中顶点y是顶点x的一个邻接点,返回除y之外顶点x的下一
个邻接点的顶点号,若y是x的最后一个邻接点,则返回-1。
• Get_edge_value(G,x,y):获取图G中边(x, y)或<x, y>对应的权值。
• Set_edge_value(G,x,y,v):设置图G中边(x, y)或<x, y>对应的权值为v。
此外,还有
图的遍历算法
\color{red}图的遍历算法
图的遍历算法,包括深度优先遍历和广度优先遍历。