博客
关于我
数据结构 第六章 图-1
阅读量:355 次
发布时间:2019-03-04

本文共 2755 字,大约阅读时间需要 9 分钟。

图论是计算机科学中的一个重要分支,涉及图的结构、性质及其应用。以下是图论的一些基本概念和相关内容的详细阐述。

图的基本概念

图是由顶点和边组成的数据结构,其中:

  • 顶点(Vertex):图中元素的基本单元,通常用V表示顶点集合。
  • 边(Edge):连接两个顶点的关系,通常用E表示边集合。边可以是无向的,也可以是有向的。

邻接关系

  • 两个顶点若直接连接,则称为邻接。例如,边e=(u, v)意味着顶点u和v是邻接的。
  • 邻接关系是图的基本性质,决定了图的结构和特性。

关联关系

  • 顶点与其连接的边的关系称为关联关系。每个顶点可以关联多条边,反之亦然。

入度与出度

  • 入度(In-Degree):以某顶点为终止点的边的数量。
  • 出度(Out-Degree):以某顶点为起始点的边的数量。
  • 入度和出度是顶点的度量指标,常用于分析图的结构和特性。

图的类型

  • 无向图(Undirected Graph):所有边都是无向的,边(u, v)与边(v, u)相同。
  • 有向图(Directed Graph):所有边都是有向的,边(u, v)与边(v, u)不同。
  • 混合图(Mixed Graph):图中既有无向边也有有向边。
  • 路径与通路

    • 路径(Path):由顶点和边交替组成的序列,例如π = (v0, e1, v1, e2, ..., em, vm),其中ei连接顶点Vi-1和Vi。
    • 通路(Trail):路径中不重复的边,通路的长度是边的数量。
    • 简单路径(Simple Path):路径中不重复的顶点。
    • 环路(Cycle):起止顶点相同的通路,环路长度≥1。
    • 欧拉环路(Eulerian Circuit):每条边恰好被经过一次的环路。
    • 哈密顿环路(Hamiltonian Circuit):每个顶点恰好被访问一次的环路。
    • 自环(Self-Loop):连接同一顶点的边。

    带权网络

    • 带权网络赋予每条边一个权重,常用于表示边的权重或成本。
    • 带权网络的最短路径问题可以通过Dijkstra算法或其他算法求解。

    图的复杂度

    • 图的复杂度通常用顶点数n和边数e表示,常用n + e来度量。

    图模板类

    以下是一个通用的Graph模板类定义,适用于各种图的操作:

    template
    class Graph {private: // 顶点操作 void reset() { // 初始化顶点状态、时间标签等 for (int i = 0; i < n; ++i) { status(i) = UNDISCOVERED; dTime(i) = fTime(i) = -1; parent(i) = -1; priority(i) = INT_MAX; } } void BFS(int start, int& component) { // 广度优先搜索算法 } void DFS(int start, int& component) { // 深度优先搜索算法 } void BCC(int start, int& component, Stack
    * stack) { // 基于DFS的双连通分量分解算法 } bool TSort(int start, int& component, Stack
    * stack) { // 拓扑排序算法 } template
    void PFS(int start, PU priority_queue) { // 优先级搜索框架 }public: int n; // 顶点总数 virtual int insert(Tv, const ...) = 0; virtual Tv remove(int) = 0; virtual Tv& vertex(int) = 0; virtual int inDegree(int) = 0; virtual int outDegree(int) = 0; virtual int firstNbr(int) = 0; virtual int nextNbr(int, int) = 0; virtual VStatus& status(int) = 0; virtual int* dTime(int) = 0; virtual int* fTime(int) = 0; virtual int* parent(int) = 0; virtual int* priority(int) = 0; int e; // 边总数 virtual bool exists(int, int) = 0; virtual void insert(Te, int, int, int) = 0; virtual Te remove(int, int) = 0; virtual EType type(int, int) = 0; virtual Te& edge(int, int) = 0; virtual int* weight(int, int) = 0; // 算法 void bfs() { // 广度优先搜索算法 } void dfs() { // 深度优先搜索算法 } void bcc() { // 基于DFS的双连通分量分解算法 } Stack
    * tSort() { // 拓扑排序算法 } void prim() { // 最小支撑树Prim算法 } void dijkstra() { // 最短路径Dijkstra算法 } template
    void pfs(int start, PU priority_queue) { // 优先级搜索框架 }};

    总结

    通过上述内容可以看出,图论涉及广泛的概念和技术,涵盖了图的定义、类型、路径、算法等多个方面。理解这些基本概念对于掌握图论中的高级内容和实际应用至关重要。

    转载地址:http://duir.baihongyu.com/

    你可能感兴趣的文章
    Vmware系列&虚拟机系列【仅供参考】:使用vCenter Auto Deploy制作ESXI系统封装(适合高版本vSphere)
    查看>>
    Openlayers中加载GeoJson文件显示地图
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片图层组
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片地图并显示
    查看>>
    Openlayers中多图层遮挡时调整图层上下顺序
    查看>>
    Openlayers中实现地图上添加一条红色直线
    查看>>
    Openlayers中将某个feature置于最上层
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers入门教程 --- 万字长篇
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    OpenLayers学习三:地图旋转及地图跳转到某一点的方式(以类为接口)
    查看>>
    Openlayers实战:loadstart和loadend事件
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:moveend事件,利用calculateExtent获取地图左上和右下的坐标
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:利用turf获取两个多边形的交集、差集、并集
    查看>>
    Openlayers实战:加载Bing地图
    查看>>
    Openlayers实战:加载GeoJSON
    查看>>
    Openlayers实战:加载GPX文件
    查看>>