(转)怎样选取存储结构
来源:互联网 发布:滴露 威露士 知乎 编辑:程序博客网 时间:2024/05/17 01:12
(1)顺序表的存储空间是静态分配的,在程序执行之前必须明确规定它的存储规模,也就是说事先对“MaxSize”要有合适的设定,设定过大会造成存储空间的浪费,过小造成溢出。因此,当对线性表的长度或存储规模难以估计时,不宜采用顺序表。然而,链表的动态分配则可以克服这个缺点。链表不需要预留存储空间,也不需要知道表长如何变化,只要内存空间尚有空闲,就可以再程序运行时随时地动态分配空间,不需要时还可以动态回收。因此,当线性表的长度变化较大或者难以估计其存储规模时,宜采用动态链表作为存储结构。
但在链表中,除数据域外海需要在每个节点上附加指针。如果节点的数据占据的空间小,则链表的结构性开销就占去了整个存储空间的大部分。当顺序表被填满时,则没有结构开销。在这种情况下,顺序表的空间效率更高。由于设置指针域额外地开销了一定的存储空间,从存储密度的角度来讲,链表的存储密度小于1.因此,当线性表的长度变化不大而且事先容易确定其大小时,为节省存储空间,则采用顺序表作为存储结构比较适宜。
(2)基于运算的考虑(时间)
顺序存储是一种随机存取的结构,而链表则是一种顺序存取结构,因此它们对各种操作有完全不同的算法和时间复杂度。例如,要查找线性表中的第i个元素,对于顺序表可以直接计算出a(i)的的地址,不用去查找,其时间复杂度为0(1).而链表必须从链表头开始,依次向后查找,平均需要0(n)的时间。所以,如果经常做的运算是按序号访问数据元素,显然顺表优于链表。
反之,在顺序表中做插入,删除时平均移动表中一半的元素,当数据元素的信息量较大而且表比较长时,这一点是不应忽视的;在链表中作插入、删除,虽然要找插入位置,但操作是比较操作,从这个角度考虑显然后者优于前者。
(3)基于环境的考虑(语言)
顺序表容易实现,任何高级语言中都有数组类型;链表的操作是基于指针的。相对来讲前者简单些,也用户考虑的一个因素。
总之,两种存储结构各有长短,选择哪一种由实际问题中的主要因素决定。通常“较稳定”的线性表,即主要操作是查找操作的线性表,适于选择顺序存储;而频繁做插入删除运算的(即动态性比较强)的线性表适宜选择链式存储。
- (转)怎样选取存储结构
- MySql 存储引擎的选取
- MySql存储引擎的选取
- 【转】BMP图像文件存储结构(1)
- 【转】BMP图像文件存储结构(2)
- 【转】PNG图像文件存储结构(1)
- 【转】PNG图像文件存储结构(2)
- 【转】PNG图像文件存储结构(3)
- 【转】PNG图像文件存储结构(4)
- 图的存储结构 (转)
- ORACLE数据库存储结构简介(转)
- 妊娠期发烧时怎样选取药品
- UTF-8字符串分段选取(转)
- 图的存储结构(存储、遍历)
- 树的存储结构(双亲表存储结构)
- 线性表的存储结构(顺序存储结构)
- 线性表的存储结构(链式存储结构)
- 链式存储结构(栈)
- TSS描述符表的作用
- #include<string>与#include<string.h>的区别
- curl operate elasticsearch
- Linux 内核编程指南
- JAVA IO 设计模式彻底分析
- (转)怎样选取存储结构
- RollingFileAppender和DailyRollingFileAppender
- Ubuntu 下,更改hostname后Chrome打不开
- BoundsChecker使用说明
- 清除Android工程中没用到的资源
- cloudstack4.4新增功能前瞻
- 无法打开登录所请求的数据库
- 黑马程序员-学习日记(一) JAVA基础
- mybatis 与 spring 整合