一:前言

当我们考虑用邻接表储存数据的时候,一定会拿邻接矩阵和其进行比较。邻接矩阵在储存数量较小的数据是耗费的内存是要高于邻接表的。那么我们在做题的时候如果出现内存超限,那就要注意了,可以考虑换用邻接表来储存数据了

二:相关描述

1.问题:利用邻接表来储存有向图的数据

2.测试数据:
输入: 5 8
1 2 5
1 3 8
1 5 3
2 5 6
2 3 2
3 4 10
3 5 4
4 5 11

输出:为每个顶点和其相连边的顶点以及权值
1 5 3 3 8 2 5
2 3 2 5 6
3 5 4 4 10
4 5 11
5
输出的解释说明:1 5 3 3 8 2 5 顶点1和5相连权值为3,顶点1和3相连权值为8,顶点1和2相连权值为5

3.分析如何建立邻接表使其输出上述数据
1>:首先指出,我们采取用数组模拟指针来建立链表,采用结构体数组来存储每个结点的信息
2>:结构体数组中的值为{顶点下标,边的权值,指向下一个结点的下标}
注意指向下一个结点的下标,因为我们采用的是数组来模拟指针,所以我们的head 和 next
都是记录结构体的数组下标,而head[i] 中的 i才是真正的顶点下标
3>:模拟指针为空的状况我们采用 当 next的值为0是表示为空
4>:建立链表和遍历链表请看代码

4.图示邻接表


5.示例当中的邻接表和

代码中链表插入的过程

三:上码


/**1.问题:利用邻接表来储存有向图的数据2.测试数据: 输入: 5 81 2 51 3 81 5 32 5 62 3 23 4 103 5 44 5 11输出:为每个顶点和其相连边的顶点以及权值1 5 3 3 8 2 5   2 3 2 5 63 5 4 4 104 5 115  输出的解释说明:1 5 3 3 8 2 5 顶点1和5相连权值为3,顶点1和3相连权值为8,顶点1和2相连权值为5                     3.分析如何建立邻接表使其输出上述数据1>:首先指出,我们采取用数组模拟指针来建立链表,采用结构体数组来存储每个结点的信息2>:结构体数组中的值为{顶点下标,边的权值,指向下一个结点的下标} 注意指向下一个结点的下标,因为我们采用的是数组来模拟指针,所以我们的head 和 next都是记录结构体的数组下标,而head[i] 中的 i才是真正的顶点下标3>:模拟指针为空的状况我们采用 当 next的值为0是表示为空4>:建立链表和遍历链表请看代码
**/#include<bits/stdc++.h>
using namespace std;
#define max 20000struct Node{int to;//到达某个点 int val;//边的权值 int next;//指向下一个结点下标
} node[max];int head[max] = {0},n,m,num = 0;//head为记录结构体下标,num为结构体的下标 //建立链表 这个过程类似于头插法,每次插入都插入到上一个结点的前面
void add(int from,int to,int val){num++; node[num].to = to; node[num].val = val;node[num].next = head[from];//指向下一个结点的下标 head[from] = num;//记录结构体数组的下标,下次插入的时候指向其
} int main(){cin >> n >> m;for(int i = 0; i < m; i++){int from,to,val;cin >> from >> to >> val;add(from,to,val);//add(to,from,val); 这里表示的是无向图中邻接表 } //遍历邻接表for(int i = 1; i <= n; i++){//因为顶点是从1开始的cout << i << ' ';for(int j = head[i]; j != 0; j = node[j].next){ //遍历顶点为i的链表  直到结构体的下标为0 cout << node[j].to << ' '<< node[j].val << ' '; } cout << endl;} } //5 8
//1 2 5
//1 3 8
//1 5 3
//2 5 6
//2 3 2
//3 4 10
//3 5 4
//4 5 11

四:书上的例子创建邻接表(有亿点麻烦)

//邻接表是图的一种链式存储结构,对图的每个顶点建立一个单链表,单链表第一个结点存放顶点信息,其余存放有关边信息。
//邻接表由表头结点表和边表组成。
// (01) LGraph是邻接表对应的结构体。
// vexnum是顶点数,edgnum是边数;vexs则是保存顶点信息的一维数组。// (02) VNode是邻接表顶点对应的结构体。
// data是顶点所包含的数据,而first_edge是该顶点所包含链表的表头指针。// (03) ENode是邻接表顶点所包含的链表的节点对应的结构体。
// ivex是该节点所对应的顶点在vexs中的索引,而next_edge是指向下一个节点的
#include<stdio.h>
#include<stdlib.h>
#define Max 100
typedef struct Graph* ptrGraph;
typedef struct Edgenode* ptrEdgenode;
typedef struct Edgenode{//边结点int adjvex;//边结点位置下标struct Edgenode* next;
}edgenode;
typedef struct Vnode{//顶点int Data;struct Edgenode* firstarc;
}vnode;
typedef struct Graph{struct Vnode AdjList[Max];int Nv;int Ne;
}graph;
int locateVex(ptrGraph G,int v){//根据v点信息,找到相应坐标int i;for(i=0;i<G->Nv;i++){if(G->AdjList[i].Data==v){return i;}}return -1;
}
int CreatGraph(ptrGraph G){int i,j;int V1,V2,K1,K2;ptrEdgenode p1,p2;scanf("%d%d",&G->Nv,G->Ne);//输入头结点(即顶点的数据)for(i=0;i<G->Nv;i++){scanf("%d",&G->AdjList[i].Data);G->AdjList[i].firstarc=NULL;}//输入边的两个结点for(j=0;j<G->Ne;j++){scanf("%d%d",&V1,&V2);K1=locateVex(G,V1);K1=locateVex(G,V2);p1=(ptrEdgenode)malloc(sizeof(struct Edgenode));p1->adjvex=K1;p1->next=G->AdjList[K2].firstarc;//链表前插法G->AdjList[K2].firstarc=p1;p2=(ptrEdgenode)malloc(sizeof(struct Edgenode));p2->adjvex=K2;p2->next=G->AdjList[K1].firstarc;G->AdjList[K1].firstarc=p2;}return 0;}
void output_AL(ptrGraph G)  //输出
{int i;for( i=0;i<G->Nv;i++){printf("顶点%d",G->AdjList[i].Data);ptrEdgenode p=G->AdjList[i].firstarc;while(p!=NULL){printf("->%d",p->adjvex); //输出下标//printf("->%c",G.AdjList[p->adjvex].data);  //输出顶点元素p=p->next;}printf("\n");}
}int main()
{ptrGraph G;CreatGraph(G);// output_AL(G);return 0;
}

临界表储存图的数据(思路+详解+图示)相关推荐

  1. 763. 划分字母区间009(贪心算法+思路+详解+图示)

    一:题目: 字符串 S 由小写字母组成.我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中.返回一个表示每个字符串片段的长度的列表. 示例: 输入:S = "ababcba ...

  2. python处理excel大数据-Python实现大数据收集至excel的思路详解

    一.在工程目录中新建一个excel文件 二.使用python脚本程序将目标excel文件中的列头写入,本文省略该部分的code展示,可自行网上查询 三.以下code内容为:实现从接口获取到的数据值写入 ...

  3. 03 mysql数据查询_MySql学习day03:数据表之间的连接、查询详解

    主键: 关键字:primary key 特点:不能为null,并且唯一. 主键分类: 逻辑主键:例如ID,不代表实际的业务意义,只是用来唯一标识一条记录(推荐) 业务主键:例如username,参与实 ...

  4. python更新数据库表的时间字段_python更新数据库中某个字段的数据(方法详解)

    连接数据库基本操作,我把每一步的操作是为什么给大家注释一下,老手自行快进. 请注意这是连接数据库操作,还不是更新. import pymysql #导包 #连接数据库 db = pymysql.con ...

  5. 三、教你搞懂渐变堆叠面积图《手把手教你 ECharts 数据可视化详解》

    注:本系列教程需要对应 JavaScript .html.css 基础,否则将会导致阅读时困难,本教程将会从 ECharts 的官方示例出发,详解每一个示例实现,从中学习 ECharts . ECha ...

  6. java excel中重复数据 事务处理_Java导出excel时合并同一列中相同内容的行思路详解...

    一.有时候导出Excel时需要按类别导出,一大类下好几个小类,小类下又有好几个小小类,就像下图: 要实现这个也不难, 思路如下:按照大类来循环,如上就是按照张江校区.徐汇校区.临港校区三个大类循环,然 ...

  7. FPGA串口(UART)通信协议制定与设计思路详解示例

    串口(UART)通信协议制定与设计思路详解 1 概述 本文用于描述规定的串口通信协议,以及传输内容. 2 项目关于串口的要求 a) 支持BIT自检,1路UART上报BIT信息: b) 1路UART接口 ...

  8. 2021年美赛A题思路详解

    2021年数模美赛A题思路详解 题目分析 思路详解 由于和队友思路不一致,导致最后我的思路只算了前两问,而后几问用了我认为离题的PCA(主成分分析)的方法,我的建模思路没有得到完全实现,总体情况很不满 ...

  9. Pinterest 3.0 for iOS设计过程——升级iOS7设计思路详解

    Pinterest 3.0 for iOS设计过程--升级iOS7设计思路详解 时间2013-12-11 11:39:31  苹果开发中文站 原文  http://www.cocoachina.com ...

最新文章

  1. (转载)(官网)UE4--Character
  2. 下载nodejs的mysql安装包下载_nodejs安装包下载|nodejs(javascript运行环境) v5.3.0 最新稳定版 - 软件下载 - 绿茶软件园|33LC.com...
  3. c++内存管理优化之ptmalloc,tcmalloc,jemalloc使用实例
  4. C语言 枚举,进制,原码,反码,补码,移码,结构体
  5. 为什么 SAP 电商云 Spartacus UI SSR 模式下的客户端应用,不会发起 product 请求
  6. Linux进阶之路————Linux磁盘分区与挂载
  7. OpenCV4每日一练day5:图像读取、显示与保存
  8. 在db2中 两个数据库之间的两个表的联合查询
  9. Java数据结构和算法-二叉树
  10. oracle帮助系统,Oracle1 0g扩展的帮助文件的安装
  11. stepmania谱面下载、安装、转谱,音游相关 osu etterna
  12. idea安装axios
  13. 互联网大厂的薪资和职级一览
  14. 小米笔记本bios版本大全_RedmiBook 14笔记本评测:初来乍到却熟路轻辙
  15. web网页播放音频文件
  16. qps tps rps 区别
  17. ZYNQ裸板:串口篇
  18. MCE | 靶向 cGAS-STING 通路或可治疗渐冻症
  19. CVE-2020-25540:ThinkAdmin未授权列目录/任意文件读取漏洞复现
  20. 简明 CSS2.1 参考手册

热门文章

  1. centos6.6 源码安装mysql5.5_CentOS6.x下源码安装MySQL5.5
  2. 【ArcGIS遇上Python】ArcGIS python计算长时间序列多个栅格数据的平均值
  3. ENVI IDL读写数据
  4. 数据结构之判断一棵树是不是完全二叉树
  5. Struts2的ResultType和Action处理链
  6. amap vueamap 与_在vue中使用高德地图vue-amap
  7. makefile运行_NVDIA TX2入门 系列之三:运行Yolov3
  8. mysql bigint转string_无语了,直到今天,我才揪出MySQL磁盘消耗迅猛的“真凶”!...
  9. 豆瓣评分9.4!这一部纪录片,探秘中国人迹罕至的未至之境!
  10. 你们数学老师当年是怎么叫这些符号的…