线性表--数组和链表的区别

原创 2015年07月07日 07:41:18

数组是将元素在内存中连续存放,从栈中分配空间,由于每个元素占用内存相同,可以通过下标迅速访问数组中任何元素。但是如果要在数组中增加一个元素,需要移动大量元素,在内存中空出一个元素的空间,然后将要增加的元素放在其中。同样的道理,如果想删除一个元素,同样需要移动大量元素去填掉被移动的元素。增加和删除操作的效率并不高如果应用需要快速访问数据,很少或不插入和删除元素,就应该用数组。



链表恰好相反,链表中的元素在内存中不是顺序存储的,从堆中分配空间,而是通过存在元素中的指针联系到一起。比如:上一个元素有个指针指到下一个元素,以此类推,直到最后一个元素。如果要访问链表中一个元素,需要从第一个元素开始,一直找到需要的元素位置。但是增加和删除一个元素对于链表数据结构就非常简单了,只要修改元素中的指针就可以了。如果应用需要经常插入和删除元素你就需要用链表数据结构了


(1) 从逻辑结构角度来看
     a, 数组必须事先定义固定的长度(元素个数),不能适应数据动态地增减的情况。当数据增加时,可能超出原先定义的元素个数;当数据减少时,造成内存浪费。
     b,链表动态地进行存储分配,可以适应数据动态地增减的情况,且可以方便地插入、删除数据项。(数组中插入、删除数据项时,需要移动其它数据项)
(2)从内存存储角度来看
     a,(静态)数组从栈中分配空间, 对于程序员方便快速,但自由度小。
     b, 链表从堆中分配空间, 自由度大但申请管理比较麻烦.

相关文章推荐

顺序表 线性表 数组的区别

数组就是相同数据类型的元素按一定顺序排列的集合。 一句话:就是物理上存储在一组联系的地址上。也称为数据结构中的物理结构。 线性表中数据元素之间的关系是一对一的关系,即除了第一个和最后一...

数组和链表的区别

数组结构:        数组结构在通过索引进行查询数据时效率比较高,而对于数组插入和删除操作,则效率会比较低,在第一个位置进行插入数据,其余数据就需要依次向后移动,而第一个数据进行删除,则需要所有数...

线性表和链表的区别

线性表,和链表。 线性表 线性表在内存中是一块连续的存储空间;如:一个表中的内容是:【1,2,3】则它在内存中可能是如下存储的: 1 2 3 通过这个结构可以看出,只要知道了第一个元素在内存中所在的...

线性表之顺序表与单链表的区别及优缺点

这里比较的是基于C语言实现的顺序表与单链表,与其他语言的实现可能会有差异,但我相信语言是相通的,它们的实现机制应该也差不多。 1、What 什么是顺序表和单链表 ①顺序表: 顺序表是在计算机内...

线性表、链表的区别

存储类别 顺序存储结构 单链表 存储分配方式 用一段连续的存储单元依次存储线性表的数据元素 采用链式存储结构,用一组任意的存储单元存放线性表的元素 时间性能 查找O(1)、插入...

程序员修炼之路-(2)线性表(上):数组与链表

1 两块基石数组与链表构成各种数据结构的基石,是实现所有数据结构必不可少的元素。1.1 数组数组一般内置于编程语言中,直接通过索引(index)读写。索引一般为数字,有的语言甚至直接支持如字符串等其他...
  • dc_726
  • dc_726
  • 2015年03月31日 21:18
  • 1852

数组、链表、堆栈和队列、线性表和顺序表

转自http://blog.csdn.net/amork/article/details/7258216 数据结构:是指相互之间存在一种或多种特定关系的数据元素的集合。听起来是不是很抽象,简单理解:...

第二章 2.4 线性表的第二类:链式数组表

如前所述,链式思想的数组表,把需要存储的额外信息存放在”左边结构体“中,数据元素本身存放在”右边数组“中。 这样解决了单纯数组表的一些缺陷,又最大化的保留其优点。 链式数组表根据“右边数组”的构成...

Java数据结构笔记2——数组线性表类(ArrayList)

图1 . ArrayList在Java集合框架中的位置 数组线性表类(ArrayList)和链表类(LinkedList)是实现List的两个链表类,ArrayList是基于数组的,也就是说...

索引——我们为什么要用索引

很多时候有人会问我们为啥要用数据库,把数据存放在一个文件中不就行啦,而且数据库连接,操作,那么麻烦。其实我当初也有过这种疑问,想来好笑。也许到现在我也没有真正地弄懂数据库究竟有哪些作用,但是我知道,数...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:线性表--数组和链表的区别
举报原因:
原因补充:

(最多只允许输入30个字)