vector 邻接表的建立(好笨啊,才懂,可能太困了吧)。。

Posted 吾之奉先

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vector 邻接表的建立(好笨啊,才懂,可能太困了吧)。。相关的知识,希望对你有一定的参考价值。

图的建立有两种,邻接矩阵和邻接表。

邻接矩阵适用于图较为密集,(稀疏图太浪费存储空间了),图如果较为稀疏,则使用邻接表为宜,dijkstra算法就是以邻接表为基础的。

 

有向无权图

#include<iostream>
#include <vector>
#include <algorithm>
#include <queue>
#include <stack>
using namespace std;
#define N 100000+5
vector<int >p[N];

int main()
{
    int n,m;
    cin>>n>>m;
    int start,to;
    for (int i=0;i<m;i++)
    {
        cin>>start>>to;
        p[start].push_back(to);
    }
    for (int i=1;i<=n;i++)
    {
        for (int j=0;j<p[i].size();j++)
        {
            cout<<p[i][j]<<" ";
        }cout<<endl;
    }cout<<endl;
}

无向无权图的建立:

#include<iostream>
#include <vector>
#include <algorithm>
#include <queue>
#include <stack>
#include <set>
#include <cstdio>
#include <iterator>
#include <cstring>
using namespace std;
#define N 100000+5
vector<int >p[N];

int main()
{
    int n,m;
    cin>>n>>m;
    int start,to;
    for (int i=0;i<m;i++)
    {
        cin>>start>>to;
        p[start].push_back(to);
        p[to].push_back(start);
    }
    for (int i=1;i<=n;i++)
    {
        for (int j=0;j<p[i].size();j++)
        {
            cout<<p[i][j]<<" ";
        }cout<<endl;
    }cout<<endl;
}

 

有向有权图的建立:

#include<iostream>
#include <vector>
#include <algorithm>
#include <queue>
#include <stack>
#include <set>
#include <cstdio>
#include <iterator>
#include <sstream>
#include <cmath>
#include <list>
#include <deque>
#include <cstring>
using namespace std;
#define N 100000+5
struct node
{
    int to,cost;
};
vector<node >p[N];

int main()
{
    int n,m;
    cin>>n>>m;
    int start,to;
    for (int i=0;i<m;i++)
    {
        node c;
        cin>>start>>c.to>>c.cost;
        p[start].push_back(c);
    }
    cout<<endl;
    for (int i=1;i<=n;i++)
    {
        for (int j=0;j<p[i].size();j++)
        {
            cout<<i<<" "<<p[i][j].to<<" "<<p[i][j].cost<<" "<<endl;
        }
    }cout<<endl;
}

无向有权图的建立:

 

以上是关于vector 邻接表的建立(好笨啊,才懂,可能太困了吧)。。的主要内容,如果未能解决你的问题,请参考以下文章

字典的练习

邻接表的简介

邻接表的网络存储空间很大吗

基于邻接表的拓扑排序实现

用数组表示的邻接表,如何添加一个弧

邻接表边节点是啥