legongju.com
我们一直在努力
2025-01-15 18:29 | 星期三

C++中如何实现图的表示与存储

在C++中,可以使用邻接矩阵或邻接表来表示和存储图。

邻接矩阵表示法:

#include 
#include 

using namespace std;

const int MAX_V = 100;

// 邻接矩阵表示图
class Graph {
private:
    int V; // 图中顶点数
    int E; // 图中边数
    int adj[MAX_V][MAX_V]; // 邻接矩阵

public:
    Graph(int V) {
        this->V = V;
        this->E = 0;
        for(int i = 0; i < V; i++) {
            for(int j = 0; j < V; j++) {
                adj[i][j] = 0;
            }
        }
    }

    void addEdge(int v, int w) {
        adj[v][w] = 1;
        adj[w][v] = 1;
        E++;
    }

    void printGraph() {
        for(int i = 0; i < V; i++) {
            for(int j = 0; j < V; j++) {
                cout << adj[i][j] << " ";
            }
            cout << endl;
        }
    }
};

int main() {
    Graph g(5);
    g.addEdge(0, 1);
    g.addEdge(0, 2);
    g.addEdge(1, 3);
    g.addEdge(2, 4);
    g.printGraph();

    return 0;
}

邻接表表示法:

#include 
#include 

using namespace std;

// 邻接表表示图的边
struct Edge {
    int dest; // 目标顶点
};

// 邻接表表示图的顶点
struct Vertex {
    vector edges; // 与该顶点相连的边
};

// 邻接表表示图
class Graph {
private:
    int V; // 图中顶点数
    vector adjList; // 邻接表

public:
    Graph(int V) {
        this->V = V;
        adjList.resize(V);
    }

    void addEdge(int v, int w) {
        Edge edge1 = {w};
        adjList[v].edges.push_back(edge1);

        Edge edge2 = {v};
        adjList[w].edges.push_back(edge2);
    }

    void printGraph() {
        for(int i = 0; i < V; i++) {
            cout << i << ": ";
            for(int j = 0; j < adjList[i].edges.size(); j++) {
                cout << adjList[i].edges[j].dest << " ";
            }
            cout << endl;
        }
    }
};

int main() {
    Graph g(5);
    g.addEdge(0, 1);
    g.addEdge(0, 2);
    g.addEdge(1, 3);
    g.addEdge(2, 4);
    g.printGraph();

    return 0;
}

以上分别是邻接矩阵和邻接表表示法的实现例子。你可以根据自己的需求选择合适的表示方法来实现图的表示与存储。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/110822.html

相关推荐

  • c++ mysql库的数据更新与删除操作

    c++ mysql库的数据更新与删除操作

    在C++中,可以使用MySQL C++ Connector库来进行数据更新和删除操作。以下是一个简单的示例代码,展示如何使用MySQL C++ Connector库来进行数据更新和删除操作:<...

  • c++ memset_s与memset有何不同

    c++ memset_s与memset有何不同

    memset_s 和 memset 都是 C++ 中用于设置内存区域的函数,但它们之间存在一些关键差异 安全性:memset_s 是一个更安全的版本,因为它会检查目标缓冲区的大小。如...

  • c++中使用memset_s需要注意什么

    c++中使用memset_s需要注意什么

    在C++中,memset_s函数是一个安全的内存设置函数,它可以防止缓冲区溢出 包含头文件:在使用memset_s之前,请确保已经包含了正确的头文件。对于C++,应该包含头文...

  • c++ memset_s如何安全清零内存

    c++ memset_s如何安全清零内存

    在C++中,memset_s是一个安全的方法来清零内存
    #include
    #include int main() { char buffer[100]; // 填充缓冲区 for (int i = 0; i< sizeof(buffer)...

  • C++中如何存储大量素数

    C++中如何存储大量素数

    在C++中存储大量素数可以使用一些数据结构来进行管理,以下是一些常用的方法: 使用 STL 中的 vector 或 set 来存储素数:可以用一个 vector 或 set 存储已知素数...

  • C#中redirect在不同服务器上的配置差异

    C#中redirect在不同服务器上的配置差异

    在C#中,使用redirect在不同服务器上的配置差异通常取决于服务器的配置和权限设置。以下是一些可能的配置差异: 服务器类型:不同类型的服务器(如IIS、Apache等...

  • C#中redirect在网站迁移中的应用

    C#中redirect在网站迁移中的应用

    在网站迁移过程中,可以使用redirect来帮助旧网站的访问者自动跳转到新网站,以确保用户可以顺利访问到新的网站内容。在C#中,可以通过以下代码实现redirect功能...

  • C语言中info的存储方式

    C语言中info的存储方式

    在C语言中,info的存储方式取决于info的数据类型和使用的存储位置。info可以存储在内存中的堆、栈或全局数据区中。
    如果info是一个局部变量,则它通常会存储...