首页 > 其他分享 >邻接表 存储 vector

邻接表 存储 vector

时间:2023-03-20 17:37:15浏览次数:27  
标签:存储 int back start vector 邻接 push include

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

邻接矩阵适用于图较为密集,(稀疏图太浪费存储空间了),图如果较为稀疏,则使用邻接表为宜,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;
}
复制代码

标签:存储,int,back,start,vector,邻接,push,include
From: https://www.cnblogs.com/ljq2022/p/17237068.html

相关文章

  • 存储过程
    1、查询数据CREATEDEFINER=`root`@`%`PROCEDURE`myproc`()BEGIN SELECT*frommytest;END2、插入数据(传入参数)CREATEDEFINER=`root`@`%`PROCEDURE`myinse......
  • 使用Navicat创建存储函数时传递多个参数总是报错
      当我不传递参数时,它不报错;当我只传递一个参数时,它也不报错;可当我传递多个参数时,它就是会报错!!!人都麻了 后来发现传入的参数类型如果是字符串的话,Navicat并不会......
  • 服务器存储之Raid技术详解
    (服务器存储之Raid技术详解)一、RAID介绍1.RAID理解RAID:独立磁盘冗余阵列(RedundantArrayofIndependentDrives),磁盘阵列是由很多块独立的磁盘,组合成一个容量巨大的磁......
  • 关于存储的一些知识
    1一些概念 SATA,IDE,SSD,HDD, AHCI,IntelRST,IntelVMD,Raid,PCleNVmeSSD,从接口类型分硬盘,SATA或者IDE首先说SATA(SerialadvancedtTechnologyAttachment......
  • 评论与内容的存储,一张表还是两张表
    在建站过程中遇到的第一个设计问题,就是文章与评论再数据库中如何存储,这里有两个常见的存储方式,第一种是文章与评论储存在一张表中内容与评论在一张表中存储先看代码{......
  • 盒子结构“数据的存储”
    今日份学习“数据的存储”本文简介:C语言中的数据类型有整型,字符型,浮点型,以及结构体类型,我们知道这些类型是用来专门接收各个类型的数据的,但是这些类型的数据应该放在哪里呢?......
  • 基于K8S搭建Ceph分部署存储
    基于K8S搭建Ceph分部署存储 2020年2月17日 技术、推荐博文唐玥璨7条留言版本依赖​    搭建思路很多高级运维人员都2020年了对于K8S的存储大部分都是采用主机......
  • 关于float和double类型数据在单片机内存中如何存储和转换
    关于float和double类型数据在单片机内存中如何存储和转换1、单精度浮点型float,双精度浮点型double数据在内存中的存储模型(1)下图为单精度浮点型数据float的存储模型,符号位......
  • clickhouse的数据存储原理
    ClickHouse是一个列式存储数据库,它的数据存储原理与传统的行式存储数据库有很大不同。以下是ClickHouse数据存储原理的一些关键点:列式存储:与行式存储数据库将数据按行存......
  • 路飞:文件存储、前端搜索导航栏、前端搜索页面、后端搜索接口、支付宝支付介绍、支付宝
    目录一、文件存储七牛云上传文件1.1七牛云存储空间使用1.2使用代码上传文件到七牛云二、前端搜索导航栏2.1Header.vue三、前端搜索页面3.1SearchCourse.vue3.2路由中注......