数据结构

数据结构

1.定义

一组用来保存一种或者多种特定关系的数据的集合(组织和存储数据)

程序的设计:将现实中大量而复杂的问题以特定的数据类型和特定的存储结构存储在内存中,

并在此基础上实现某个特定的功能的操作;

程序 = 数据结构 + 算法

2.数据与数据之间的关系

数据的逻辑结构:数据元素与元素之间的关系

集合:关系平等

线性结构:元素之间一对一的关系(表(数组,链表),队列。栈。。。)

树型结构:元素之间一对多的关系(二叉树)

图形结构:元素之间多对多的关系(网状结构)

数据的物理结构:数据的逻辑结构在计算机内存中的存储形式

顺序存储:采用一段连续的内存空间保存元素

优点:空间连续,访问方便

缺点:插入删除需要移动大量的元素

需要预分配内存空间

容易造成存储空间碎片

链式存储:采用一组非连续的内存空间保存元素

缺点:访问元素效率低

优点:插入和删除数据方便

不需要预分配内存

索引存储:通过关键字构建索引表,通过索引表来来找到数据的存储位置

散列存储(哈希存储):将数据元素的存储位置与关键码之间建立确定对

应关系从而实现查找的存储方式

相关推荐
星马梦缘2 小时前
aaaaa
数据结构·c++·算法
OpenApi.cc3 小时前
神经网络结构驱动+数据结构分析
数据结构·人工智能·神经网络
星恒随风4 小时前
C语言数据结构排序算法详解(下):冒泡排序、快速排序、归并排序和计数排序
c语言·数据结构·笔记·学习·排序算法
初夏睡觉5 小时前
数据结构学习之~二叉堆 (P3378 【模版】堆)
数据结构·c++·学习
云泽8086 小时前
笔试算法 - 链表篇(一):移除、反转、合并、回文判断全解析
数据结构·c++·算法·链表
也曾看到过繁星6 小时前
数据结构-复杂度
数据结构
菜菜的顾清寒6 小时前
HOT力扣100(43)二叉树-翻转二叉树
数据结构·算法·leetcode
Jasmine_llq7 小时前
《B3939 [GESP样题 四级] 绝对素数》
数据结构·算法·素数判断算法·数字拆分与反转算法·区间遍历枚举·双条件判断逻辑
郝学胜-神的一滴8 小时前
干货版《算法导论》07:递归视角下的选择排序与归并排序
java·数据结构·c++·python·程序人生·算法·排序算法
未若君雅裁9 小时前
算法复杂度与数据结构:Java 集合篇的第一块基石
java·数据结构·算法