一步一步写算法(之图的保存)

简介: 原文: 一步一步写算法(之图的保存) 【 声明:版权所有,欢迎转载,请勿用于商业用途。  联系信箱:feixiaoxing @163.com】     前面的几篇博客,我们对图进行基本定义,同时介绍了图的创建、图的添加和删除等。
原文: 一步一步写算法(之图的保存)

【 声明:版权所有,欢迎转载,请勿用于商业用途。  联系信箱:feixiaoxing @163.com】


    前面的几篇博客,我们对图进行基本定义,同时介绍了图的创建、图的添加和删除等。今天,我们聊一聊图是怎么在存储在外设中的。这些外接设备可以是各种类型的,比如说,可以是硬盘、sd卡、网络硬盘等等。本质上说,我们今天讨论的主题就是怎么把图的数据永久地保留在本地。并且,如果需要加载这些数据,也可以快速恢复图原来的面貌。对图数据结构已经记得不太清楚的朋友可以复习一下面的代码,回想一下我们之前的定义方法。

typedef struct _LINE
{
	int end;
	int weight;
	struct _LINE* next;
}LINE;

typedef struct _VECTEX
{
	int start;
	int number;
	LINE* neighbor;
	struct _VECTEX* next;
}VECTEX;

typedef struct _GRAPH
{
	int count;
	VECTEX* head;
}GRAPH;
    数据结构中有好多的指针。那么在外存中应该怎么保存呢?因为对于外存来说,指针是没有什么意义的。大家稍微思考其实就明白了。其实我们可以把这些指针全部看成是偏移值。GRAPH是有许多的点构成的,点的结构中有很多的边连接,那么我们就可以按照下面的顺序保存数据。

/*
*    ---------------------------------------------------------------------------
*    | GRAPH | vectex1 | vectex2 | ...... | vectex n   | LINE1 |......| LINE n |
*    ---------------------------------------------------------------------------
*/
    那么偏移值怎么安排呢?

    a)GRAPH结构

   head为第一个vectex的偏移地址。


    b)VECTEX结构

    neighbour记录了第一条边的偏移位置,next记录了下一个节点的偏移值。


    c)LINE结构

    next为下一条边的偏移值。


    但是,如果我们做一些优化的话,那么保存的数据还要少一些。比如说,第一个vectex的节点就在GRAPH的后面,那么head实际上不需要保存;同时在vectex结构中,因为我们需要知道LINE的偏移值,所以neighbour的偏移是需要知道的,但是next就不再需要了,因为vectex数据本身就是并列在一起的;最后同样因为我们需要把所有属于同一个vectex的边放在一起,那么LINE结构中的next数据其实也可以省略了。所以修改后保存的数据结构大体应该是这样的:

typedef struct _LINE
{
	int end;
	int weight;
}LINE;

typedef struct _VECTEX
{
	int start;
	int number;
	LINE* neighbor;
}VECTEX;

typedef struct _GRAPH
{
	int count;
}GRAPH;

    有了上面的数据结构,那么从外层加载数据就是一个逆向操作而已,不再复杂了。


目录
相关文章
|
5天前
|
算法 搜索推荐 图计算
图计算中的社区发现算法是什么?请解释其作用和常用算法。
图计算中的社区发现算法是什么?请解释其作用和常用算法。
34 0
|
5天前
|
存储 算法 测试技术
☆打卡算法☆LeetCode 133. 克隆图 算法解析
☆打卡算法☆LeetCode 133. 克隆图 算法解析
|
7月前
|
算法
带你读《图解算法小抄》七、图(5)
带你读《图解算法小抄》七、图(5)
|
5天前
|
存储 算法
图的深度优先算法
图的深度优先算法
19 0
|
5天前
|
算法 数据可视化 大数据
圆堆图circle packing算法可视化分析电商平台网红零食销量采集数据
圆堆图circle packing算法可视化分析电商平台网红零食销量采集数据
|
5天前
|
算法 搜索推荐 数据挖掘
图计算中的图算法有哪些常见的类型?请举例说明每种类型的算法。
图计算中的图算法有哪些常见的类型?请举例说明每种类型的算法。
42 0
|
5天前
|
算法 搜索推荐 Java
图计算中的PageRank算法是什么?请解释其作用和计算原理。
图计算中的PageRank算法是什么?请解释其作用和计算原理。
31 0
|
5天前
|
算法 搜索推荐 Java
图计算中的图剪枝算法是什么?请解释其作用和常用方法。
图计算中的图剪枝算法是什么?请解释其作用和常用方法。
16 0
|
6月前
|
算法 数据挖掘 知识图谱
LINE算法复现 图表示学习 基于line 算法的节点分类 聚类显示 完整代码+数据
LINE算法复现 图表示学习 基于line 算法的节点分类 聚类显示 完整代码+数据
22 0
|
7月前
|
存储 算法 图计算
TuGraph Analytics图计算快速上手之弱联通分量算法
TuGraph Analytics是蚂蚁集团近期开源的分布式流式图计算,目前广泛应用在蚂蚁集团的金融、社交、风控等诸多领域。