数组和链表的区别

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

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

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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 重新回顾了下,总结如下: 1.数组查询快:数组要求是一块连续的内存空间来存储,这就要求在物理上这一片空间是连续的,...
    InitialX阅读 8,833评论 0 8
  • 首先,二者都属于数据结构的范畴。数组一旦初始化,长度就不能改变。链表长度可以改变,可以动态的增加节点数据,操作比较...
    望月成三人阅读 5,601评论 2 4
  • 两者的区别可以从两方面: 内存存储:① 数组从栈中分配空间,对程序员方便快速,自由度小。② 链表从堆中分配内存...
    飞向大海的菜鸟阅读 7,154评论 0 1
  • 什么是runtime? 1> runtime是一套底层的C语言API(包含很多强大实用的C语言数据类型、C语言函数...
    康大侠阅读 2,870评论 0 3
  • 1.她的某些事是你从别人那里听来的,而不是她亲口告诉你的(这件事是真实发生的) 2.每次都是你主动找她聊天,她从不...
    ssuuzzyy阅读 3,297评论 0 0

友情链接更多精彩内容