百科狗-知识改变命运!
--

在C语言中数组和链表有什么区别?

乐乐1年前 (2023-12-03)阅读数 22#综合百科
文章标签数组链表

要说这个区别,你要先知道数据结构。要说清楚数据结构要一本书的内容,所以我只能抽个直接相关的东东来说一下:线性表。

线性表:

逻辑上 是一张二维表,里面有元素和相应元素的位置。

物理上 线性表以两种形式在内存中存放:顺序表和链式表。

这顺序表要求:在内存中连续的内存地址存放。(可看成数组)

而链式表不要求以连续的内存块平存放,它有一个指针域来索引到下一个节点。(链表)

性能上分析:

在C语言中数组和链表有什么区别?

顺序表(数组)可直接索引到某个元素,而链表只能从链表头(如果为单链表)开始一个一个去找,所以比顺序表要低效。

另外一方面,如果顺序表要删除或插入元素就要移动多个后面的元素,而链表则不用移动元素,只要修改指针域就行了,所以在有删除或修改动作时,链表比较高效。

当然我说的还很不全面,你可以参考一下数据结构这本书的线性表这章。

链表和数组的区别.在什么情况下用链表

,但不允许动态定义数组的大小,即在使用数组之前必须确定数组的大小。而在实际应用中,用户使用数组之前有时无法准确确定数组的大小,只能将数组定义成足够大小,这样数组中有些空间可能不被使用,从而造成内存空间的浪费。

链表是一种常见的数据组织形式,它采用动态分配内存的形式实现。需要时可以用new分配内存空间,不需要时用delete将已分配的空间释放,不会造成内存空间的浪费。

A 从逻辑结构来看

A-1. 数组必须事先定义固定的长度(元素个数),不能适应数据动态地增减的情况。当数据增加时,可能超出原先定义的元素个数;当数据减少时,造成内存浪费。

A-2. 链表动态地进行存储分配,可以适应数据动态地增减的情况,且可以方便地插入、删除数据项。(数组中插入、删除数据项时,需要移动其它数据项)

B 从内存存储来看

B-1. (静态)数组从栈中分配空间, 对于程序员方便快速,但是自由度小

B-2. 链表从堆中分配空间, 自由度大但是申请管理比较麻烦.

在知道同类数据的数量范围且不超过静态内存容许值时用数组,编程简单快速。

当你处理的同类数据的数据量未知时,或者数据量超过静态数组定义范围时,就要用链表。

=============================

普通数组在用户的静态数据空间中分配内存,链表在操作系统的堆中动态分配内存。

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)