图论:图的表示方法

2. 图的表示

2.1 邻接矩阵

邻接矩阵 是一种编程语言中用二维数组表示图的方法,更适用于节点数量够的多的 稠密图(边数接近顶点数的平方)

cpp 复制代码
class Node{
    int id;//节点的id,用于寻址
    Object obj;//存储的内容
    vector<Edge>edges;//表示与节点的出度
}
class Edge{
    /*
     *存在不同权重的边
     */
    double weight;
     /*
     *表示边的出发节点
     */
    Node* start;
    /*
     *表示边的终点
     */
    Node* end;
}

/*
 * 用邻接矩阵来表示图:Graph m个节点 n条边
 * 用给出的边的关系来初始化整个邻接矩阵
 * 邻接矩阵表示为:
 * * * * * * *> 横轴表示目标节点
 * *
 * *    adjMat[y][x]=weight 表示y节点和x节点之间边权重
 * *    weight = 0 说明从 y节点不能直接到x节点
 * *    weight!=0 说明从 y节点能直接到x节点
 * *
 * V纵轴表示出发节点
 */
int main(){
    vector<vector<double>>adjMatrix(n,vector<double>(n));
    vector<Edge>Graph(n);
    for(Edge edge:Graph){
        adjMatrix[edge.start.id][edge.end.id]=edge.weight;
    }
}

2.2 邻接表

邻接表 是由一个顶点数组和多个链表组成,每一个顶点都有一个链表来表示与顶点相连的边 (在关系不需要多次变动的情况下可以用vector来优化)

cpp 复制代码
class Node{
    int id;//节点的id,用于寻址
    Object obj;//存储的内容
    vector<Edge>edges;//表示与节点的出度
}
class Edge{
    /*
     *存在不同权重的边
     */
    double weight;
     /*
     *表示边的出发节点
     */
    Node* start;
    /*
     *表示边的终点
     */
    Node* end;
}
    //用节点数组+链表实现
    vector<List<Node*>>adjList(n,List<Node>());
    vector<Edge>graph;

    for(const Edge& edge:graph){
        adjList[edge.start.id].emplace_back(edge.end);
    }
相关推荐
计信金边罗2 天前
是否存在路径(FIFOBB算法)
算法·蓝桥杯·图论
闻缺陷则喜何志丹4 天前
【二分图 图论】P9384 [THUPC 2023 决赛] 着色|普及+
c++·算法·图论·二分图·洛谷
鸽子炖汤4 天前
LRC and VIP
c++·算法·图论
JK0x076 天前
代码随想录算法训练营 Day61 图论ⅩⅠ Floyd A※ 最短路径算法
算法·图论
qq_447429416 天前
数据结构与算法:图论——拓扑排序
linux·c语言·学习·图论
zc.ovo6 天前
图论刷题1
算法·深度优先·图论
珂朵莉MM6 天前
2022 RoboCom 世界机器人开发者大赛-本科组(省赛)解题报告 | 珂学家
人工智能·算法·职场和发展·深度优先·图论
蒙奇D索大6 天前
【数据结构】图论核心算法解析:深度优先搜索(DFS)的纵深遍历与生成树实战指南
数据结构·算法·深度优先·图论·图搜索算法
ShiinaMashirol6 天前
代码随想录打卡|Day50 图论(拓扑排序精讲 、dijkstra(朴素版)精讲 )
java·图论
JK0x079 天前
代码随想录算法训练营 Day60 图论Ⅹ Bellmen_ford 系列算法
android·算法·图论