图论·图的存储

图论的存储

  • 邻接表
  • 邻接矩阵(一般不用)

邻接表

结构体数组实现

  • 缺点:如果使用结构体的话,node结构体初始化很慢。
cpp 复制代码
// common one
vector<list<int>>g;
// another type
typedef struct node{
	int val;
	int dist;// 如果需要节点到某点的距离的话
}
vector<list<node>>g;
  • 插入操作
cpp 复制代码
q.push_back(item)

链表前向星

  • 邻接表定义:
  • h代表链表头指针,指向v,nxt数组中的每一个节点
  • v代表某一个边终点节点 的具体值,nxt代表指向的边。注意这两个数组其实都是代表边 ,可能会出现1->3,2->3,3号节点对应v和nxt中不同的位置的情况!
  • v和nxt的大小等于边数
  • len代表总共有多少边。
cpp 复制代码
int h[100009], v[100009], nxt[100009], len = 0;
  • 插入操作
cpp 复制代码
void insert(int x,int y) {
	len++;
	v[len] = y;
	nxt[len] = h[x];
	h[x] = len;
	d[y]++;
}
  • 容易出错的操作:搜索时我们假定得到的是节点编号 ,但是我们nxt和h指向的是该节点的实际存储位置。
cpp 复制代码
for (int i = h[cur]; i != -1; i = nxt[i]) {
	int node = v[i];
	d[node]--;
	if (!d[node]) {
		q.push(node);
	}
}
相关推荐
一条大祥脚7 小时前
2021-2022 ICPC Southwestern Europe Regional Contest
算法·深度优先·图论
闻缺陷则喜何志丹13 小时前
【图论 树 启发式合并】P7165 [COCI2020-2021#1] Papričice|普及+
c++·算法·启发式算法·图论··洛谷
故事和你9113 小时前
洛谷-【图论2-4】连通性问题1
开发语言·数据结构·c++·算法·动态规划·图论
爱炼丹的James13 小时前
第三章 搜索和图论
数据结构·算法·图论
故事和你9114 小时前
洛谷-【图论2-4】连通性问题2
开发语言·数据结构·c++·算法·动态规划·图论
故事和你911 天前
洛谷-【图论2-3】最小生成树1
开发语言·数据结构·c++·算法·动态规划·图论
故事和你912 天前
洛谷-【图论2-3】最小生成树2
开发语言·数据结构·c++·算法·动态规划·图论
khalil10202 天前
代码随想录算法训练营Day-55 图论06 | 108.冗余连接、109.冗余连接II
c++·算法·leetcode·图论·并查集
故事和你913 天前
洛谷-【图论2-2】最短路4
开发语言·数据结构·c++·算法·动态规划·图论
ccLianLian3 天前
图论·刷题总结
算法·深度优先·图论