数据机构实验六 图的邻接表存储及遍历.docVIP

  • 2
  • 0
  • 约6.65千字
  • 约 8页
  • 2018-01-18 发布于浙江
  • 举报

数据机构实验六 图的邻接表存储及遍历.doc

数据机构实验六 图的邻接表存储及遍历

实验六 图的邻接表存储及遍历 一、实验学时 2学时 二、背景知识 1.图的邻接表存储结构 在图的邻接表中,图中每个顶点都建立一个单链表,第i个单链表中的结点数为顶点i的出度。(逆邻接表中,第i个单链表中的结点数为顶点i的入度) 邻接表的数据结构描述为: struct node { int vertex; struct node *nextnode; }; typedef struct node *graph; struct node head[vertexnum]; 2.图的遍历 深度优先遍历(DFS)法: 算法步骤: 1)初始化: (1)置所有顶点“未访问”标志; (2)打印起始顶点; (3)置起始顶点“已访问”标志; (4)起始顶点进栈。 2)当栈非空时重复做: (1)取栈顶点; (2)如栈顶顶点存在被访问过的邻接顶点,则选择一个顶点做: ① 打印该顶点; ② 置顶点为“已访问”标志; ③ 该顶点进栈; 否则,当前栈顶顶点退栈。 3)结束。 广度优先遍历(BFS)法: 算法步骤: 1) 初始化: (1)置所有顶点“未访问”标志; (2)打印起始顶点; (3)置起始顶点“已访问”标志; (4)起始顶点入队。 2)当队列非空时重复做: (1)取队首顶点; (2)对与队首顶点邻接的

文档评论(0)

1亿VIP精品文档

相关文档