博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
线性表和数组的区别
阅读量:6598 次
发布时间:2019-06-24

本文共 729 字,大约阅读时间需要 2 分钟。

数组

  数组就是相同数据类型的元素按一定顺序排列的集合。本质:物理上存储在一组联系的地址上,也就是数据结构中的顺序存储物理结构。

  数组分为静态数组动态数组,在定义数组时,首先要确定数组的大小。

  静态数组在编译时就需要确定数组的大小,所以,为了防止内存溢出,我们尽量将数组定义的大一些,但是这样太过浪费内存。

  动态数组则不同,它不需要在编译时就确定大小,它的大小在程序运行过程中确定,所以可以根据程序需要而灵活的分配数组的大小,相比静态数组,它更“灵活”、“自由”。但是动态数组需要进行显式的内存释放。

 

线性表

  线性表中数据元素之间的关系是一对一的关系,即除了第一个和最后一个数据元素之外,其它数据元素都是首尾相接的。本质:线性表是数据结构中的逻辑结构。线性表可以通过数组(顺序存储结构)存储,也可以通过链式存储。

  线性表根据存储结构的不同可以分为顺序表和链表。其中,顺序表为顺序存储的线性表,即用数组描述的线性表就是顺序表;链表为链式存储的线性表。

  链表可以根据描述方式的不同分为静态链表动态链表。通过指针对链表进行描述的称为动态链表,如我们常说的单链表,循环链表等;通过数组对链表进行描述的称为静态链表,主要为了解决没有指针或者不用指针的情况下具备链表插入删除操作便捷的特性。

 

注意

  看到很多人直接将顺序表等同于动态数组,认为实现了数组长度可变,数据可删减,但这样做容易造成概念混淆。我们可以通过数组实现顺序表,但动态数组的概念并不是实现数组长度可变,而是通过new操作符或malloc函数实现运行时内存的动态分配。

转载于:https://www.cnblogs.com/qinguoyi/p/10405527.html

你可能感兴趣的文章
无需认证的mail,适用于ZABBIX等运维系统
查看>>
程序员必看的十大电影
查看>>
如何在Linux系统上监测系统温度?
查看>>
【转载】【原创】生命中,要有自己的一方晴天
查看>>
Python selectors
查看>>
前端优化网站性能的14条规则
查看>>
VC2010 ADO 写入二进制数据到数据库 下载二进制数据到文件
查看>>
Win 2003 安装 IIS SNMP 无法复制 .vbs .dll 等文件 怎么办 解决办法
查看>>
2015 成长计划
查看>>
禁止用户远程登录ssh访问控制设置
查看>>
RHEL6.3配置FTP服务器(2) 本地用户下载和上传
查看>>
oracle数据库开机自启
查看>>
bash基础特性
查看>>
字符与字符串
查看>>
R语言实战(八)广义线性模型
查看>>
python模糊查找匹配 文件 文件名 并列出来
查看>>
系統用戶管理
查看>>
CCIE/CCDE笔试考试政策
查看>>
微软自学之TechNet
查看>>
11.22红帽OpenStack技术研讨会诚邀您免费参加
查看>>