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

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

数组是线性结构,可以直接索引,即要去第i个元素,a[i]即可。链表也是线性结构,要取第i个元素,只需用指针往后遍历i次就可。貌似链表比数组还要麻烦些,而且效率低些。

想到这些相同处中的一些细微的不同处,于是他们的真正不同处渐渐显现了:链表的效率为何比数组低些?先从两者的初始化开始。数组无需初始化,因为数组的元素在内存的栈区,系统自动申请空间。而链表的结点元素在内存的堆区,每个元素须手动申请空间,如malloc。也就是说数组是静态分配内存,而链表是动态分配内存。链表如此麻烦为何还要用链表呢?数组不能完全代替链表吗?回到这个问题只需想想我们当初是怎么完成学生信息管理系统的。为何那时候要用链表?因为学生管理系统中的插入,删除等操作都很灵活,而数组则大小固定,也无法灵活高效的插入,删除。因为堆操作灵活性更强。数组每次插入一个元素就需要移动已有元素,而链表元素在堆上,无需这么麻烦。

说了这么多,数组和链表的区别整理如下:

数组静态分配内存,链表动态分配内存;

数组在内存中连续,链表不连续;

数组元素在栈区,链表元素在堆区;

数组利用下标定位,时间复杂度为O(1),链表定位元素时间复杂度O(n);

数组插入或删除元素的时间复杂度O(n),链表的时间复杂度O(1)。

转载地址:http://ebckx.baihongyu.com/

你可能感兴趣的文章
与数论的厮守03:大步小步算法
查看>>
JQuery打印
查看>>
POJ 1469 COURSES【最大匹配】
查看>>
集成学习
查看>>
C++ 构造函数初始化列表
查看>>
Linux设置开机界面模式
查看>>
svn服务器 备份,迁移,部署方案
查看>>
安装,配置 SMTP 服务器
查看>>
使用docker-compose运行springcloud项目
查看>>
NLPIR智能语义挖掘文本大数据深层意义
查看>>
此次项目之用户手册
查看>>
UML类图几种关系的总结(转发)
查看>>
第八章:Java集合
查看>>
关于json的中文转码问题
查看>>
android微信支付
查看>>
LeetCode算法题-Pascal's Triangle II(Java实现)
查看>>
性能测试初学_利用cookie 绕过登录
查看>>
iOS RC4加解密算法
查看>>
rpc-远程调用框架
查看>>
dbgrid中没有数据原因1
查看>>