【C++学习笔记】 链式前向星
链式前向星是一种常见的储存图的方式(是前向星存图法的优化版本),支持增边和查询,但不支持删边(如果想要删除指定的边建议用邻接矩阵)。
- 储存方式
首先定义数组 head[ i ] 来储存从节点 i 出发的第一条边的下标,定义结构体 edge[ i ] 中包含三个元素 nxt, to, val, 分别储存从节点 i 出发的下一条边的下标(nxt),该边的终点(to), 该边的边权(val)。
struct EDGE {
int nxt, to, val; /* 下一条边的下标, 这条边的终点, 边权 */
};
EDGE edge[maxn]; int head[maxn]; /* head[ i ]储存从节点 i 出发的第一条边的下标 */
- 添加节点
定义变量 cnt 表示当前边的编号(初始值为0),具体如代码所示。
int cnt = ; void add ( int st, int ed, int v ) {
edge[ ++cnt ].nxt = head[st];
edge[cnt].to = ed;
edge[cnt].val = v;
head[st] = cnt; /*
edge[ ++cnt ].nxt = head[ed]; * 如果是无向图就加上这个语句
edge[cnt].to = st;
edge[cnt].val = v;
head[ed] = cnt; */ }
- 节点的遍历
从数据结构就可以看出来,上代码。
/* i 是作为原点的节点编号 */
for ( int j = head[i]; j != ; j = edge[j].nxt ) /* <-- 链式前向星遍历的关键 */
printf ( "-->%d || val = %d \n", edge[j].to, edge[j].val );
}
- 汇总代码
#include <cstdio>
#include <cstring> using namespace std; const int maxn = ; struct EDGE {
int nxt, to, val; /* 下一条边的下标, 这条边的终点, 边权 */
};
EDGE edge[maxn]; int head[maxn], cnt = ; /* head[ i ]储存从节点 i 出发的第一条边的下标 */ void add ( int st, int ed, int v ) {
edge[ ++cnt ].nxt = head[st];
edge[cnt].to = ed;
edge[cnt].val = v;
head[st] = cnt; /*
edge[ ++cnt ].nxt = head[ed]; * 如果是无向图就加上这个语句
edge[cnt].to = st;
edge[cnt].val = v;
head[ed] = cnt; */ } int main () {
memset ( head, , sizeof head );
int n, m;
scanf ( "%d%d", &m, &n ); /* 共有 m 个节点, n 条边 */
for ( int i = ; i <= n; i ++ ){
int a, b, c;
scanf ( "%d%d%d", &a, &b, &c );
add ( a, b, c );
}
for ( int i = ; i <= m; i ++ ){
printf ( "开始以节点%d为原点\n", i );
for ( int j = head[i]; j != ; j = edge[j].nxt ) /* <-- 链式前向星遍历的关键 */
printf ( "-->%d || val = %d \n", edge[j].to, edge[j].val );
}
return ;
}
【C++学习笔记】 链式前向星的更多相关文章
- poj-1459-最大流dinic+链式前向星-isap+bfs+stack
title: poj-1459-最大流dinic+链式前向星-isap+bfs+stack date: 2018-11-22 20:57:54 tags: acm 刷题 categories: ACM ...
- 链式前向星+SPFA
今天听说vector不开o2是数组时间复杂度常数的1.5倍,瞬间吓傻.然后就问好的图表达方式,然后看到了链式前向星.于是就写了一段链式前向星+SPFA的,和普通的vector+SPFA的对拍了下,速度 ...
- 单元最短路径算法模板汇总(Dijkstra, BF,SPFA),附链式前向星模板
一:dijkstra算法时间复杂度,用优先级队列优化的话,O((M+N)logN)求单源最短路径,要求所有边的权值非负.若图中出现权值为负的边,Dijkstra算法就会失效,求出的最短路径就可能是错的 ...
- hdu2647 逆拓扑,链式前向星。
pid=2647">原文地址 题目分析 题意 老板发工资,可是要保证发的工资数满足每一个人的期望,比方A期望工资大于B,仅仅需比B多1元钱就可以.老板发的最低工资为888元.输出老板最 ...
- 图的存储结构:邻接矩阵(邻接表)&链式前向星
[概念]疏松图&稠密图: 疏松图指,点连接的边不多的图,反之(点连接的边多)则为稠密图. Tips:邻接矩阵与邻接表相比,疏松图多用邻接表,稠密图多用邻接矩阵. 邻接矩阵: 开一个二维数组gr ...
- 【模板】链式前向星+spfa
洛谷传送门--分糖果 博客--链式前向星 团队中一道题,数据很大,只能用链式前向星存储,spfa求单源最短路. 可做模板. #include <cstdio> #include <q ...
- zzuli 2131 Can Win dinic+链式前向星(难点:抽象出网络模型+建边)
2131: Can Win Time Limit: 1 Sec Memory Limit: 128 MB Submit: 431 Solved: 50 SubmitStatusWeb Board ...
- HDU1532 Drainage Ditches SAP+链式前向星
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- zzuli 2130: hipercijevi 链式前向星+BFS+输入输出外挂
2130: hipercijevi Time Limit: 1 Sec Memory Limit: 128 MB Submit: 595 Solved: 112 SubmitStatusWeb B ...
随机推荐
- chapter09
import java.io.File import java.nio.file._ import scala.collection.mutable.ArrayBuffer/** * Created ...
- TCP/IP三次握手与四次挥手的正确姿势
0.史上最容易理解的:TCP三次握手,四次挥手 https://cloud.tencent.com/developer/news/257281 A 理解TCP/IP三次握手与四次挥手的正确姿势http ...
- grep-检索文本
grep -r bes.dsf.server.zookeeper ./ //递归搜索,不支持指定文件类型 find ./ -name "*.entity.xml" -exec gr ...
- matlab 基本操作
导入excel 右键excel文件, import data, 选择column vector点击导入即可, 在右侧的workspace就可以看到添加的列变量了 在workspace中右键添加clas ...
- 性能测试学习第十一天_Analysis
Analysis的功能:对测试运行结果进行查看,分析和比较 导入分析文件:loadrunner results文件和analysis session文件 Analysis窗口: 1.会话浏览器窗格 2 ...
- C#字符串自增自减算法
本文URL:http://www.cnblogs.com/CUIT-DX037/p/6770535.html 实现字符串自增和自减运算: 1.数字从 0-9 变化: 2.字母从 A-Z.a-z 变化: ...
- Magento 中一个订单的“生命历程”
当我们在网上愉快的买买买的时候, 你知道在这些屏幕“背后”正在进行着什么吗? 1. 当一个产品被加入到购物车后, 实际上发生了什么? 当第一个产品被加入到购物车, 系统首先会生成一个 quote (q ...
- Atcoder训练计划
争取三天做完一套吧,太简单的就写一句话题解吧(其实也没多少会做的). 自己做出来的在前面用*标记 agc007 *A - Shik and Stone 暴力dfs即可,直接判断个数 *B - Cons ...
- JS转换日期格式
// 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h).分(m).秒(s).季度(q) 可以用 1-2 个占位符, // 年(y)可以用 1-4 个占 ...
- Ubuntu 安装boost 库
使用 apt-get进行安装 sudo apt-get install libboost-dev