什么是数据结构?

简介: 什么是数据结构?

数据结构是计算机存储、组织数据的方式


一、线性结构


1667907817785.jpg

上图就是一个简单的线性表。


线性表是具有n个相同类型元素的有限序列(n>=0)

1667907830237.jpg

a1是首节点(首元素),an是尾节点(尾元素)


a1是a2的前驱, a2是a1的后继


常见的线性表有:数组、链表、栈、队列、哈希表


二、树形结构


1667907848740.jpg


常见的树形结构有:二叉树、AVL树、红黑树、B树、堆、Tire、哈夫曼树、并查集


树的基本概念:


1.节点、根节点、父节点、子节点、兄弟节点


2.一棵树可以没有什么节点,此时为空树


3.一棵树可以只有1个节点,此时为根节点


4.节点的度:子树的个数


5.树的度:所有节点度中的最大值


6.叶子节点:度为0的节点


7.非叶子节点:度不为0的节点


8. 层数:根节点在第一层,根节点的子节点在第二层,依次类推


9.节点的深度:从根节点到当前节点的唯一路径上的节点总数


10.节点的高度:从当前节点到最远叶子节点的路径上的节点总数


11.树的深度:所有节点深度中的最大值


12.树的高度:所有节点高度中的最大值


13.树的深度等于树的高度


三、图形结构


1667907870403.jpg


图由顶点和边组成,一般表示为G=(V,E)


G表示一个图,V是顶点集,E是边集


顶点集V有穷且非空


任意两个顶点之间都可以用边来表示它们之间的关系,边集E可以是空的


1667907886845.jpg


总结


在实际应用中,可以根据使用场景来选择最合适的数据结构


相关文章
|
6月前
|
NoSQL 容器 消息中间件
数据结构 2.2.3
数据结构 2.2.3
|
6月前
|
存储 程序员 定位技术
什么是数据结构
什么是数据结构
109 1
|
5月前
|
存储 算法 调度
|
6月前
|
算法 C++ 开发者
【C/C++ 数据结构 】 连通图的基本了解
【C/C++ 数据结构 】 连通图的基本了解
91 0
|
存储 容器
|
6月前
|
算法
数据结构22
数据结构22
24 0
|
存储 算法 搜索推荐
【BaseArray 数据结构】
【BaseArray 数据结构】
|
存储 机器学习/深度学习
|
存储 算法 C语言
数据结构成神篇1-初学数据结构
今天我们开始数据结构的学习,当然,这个有些概念是十分抽象的,只看文章是不一定能懂的,或者说会耗费不少的时间。所以我会持续在B站上面更新讲解视频,都是自己的一些理解和想法。会拿出来和大家一起分享,都是免费的。原创不易,希望大家可以三连支持一下,也希望能给大家带来进步。
98 0
数据结构成神篇1-初学数据结构
数据结构94-深入链地址法
数据结构94-深入链地址法
59 0
数据结构94-深入链地址法