数据结构与算法-数据结构(数组)

数组是最基本的数据结构之一,当然我们每天也都在使用数组,那么你知道数组的CURD的操作的背后是什么吗?我来说一下,也可能有错误的地方,欢迎大佬指出!
【数据结构与算法-数据结构(数组)】在面试时候,进常会被问这么一个问题,数组和链表的区别是什么?

数组优点:
  • 支持随机访问
  • 查找速度快
数组缺点:
  • 插入和删除效率低,可能会造成浪费内存的问题
  • 大小固定,不支持动态扩展
  • 要求内存空间必须连续
链表优点:
  • 插入删除速度快
  • 不需要固定大小
链表缺点:
  • 不能随机查找,必须从第一个开始遍历,查找效率低
复杂度比较:
  • 数组根据下标进行访问时,时间复杂度为O(1),进行插入和删除操作时,时间复杂度为O(n)
  • 链表进行访问时,时间复杂度为O(n),进行插入和删除时,时间复杂度为O(1)
不知道你们有没有想过数组的插入和删除为什么效率不高?
这里明确一下数组的官方定义,后面我们会用到,数组(Array):是用一组连续的内存空间,来存储一组相同类型的数据结构,是一种 线性表
那么到这里你可能就会有点懂了,没错,数组是一种线性表结构,当你要插入或者删除某个数据的时候,剩下的数据或者部分的数据都需要向前、或许向后移动一次或者几次这样才能实现插入或者删除,这也就是说为什么数组不适合插入和删除操作的根本原因
和数组类似的还有我们每天都在使用的像ArrayList之类的,这种我们叫做容器类(就是封装了某一种基本数据类型的类)
那么就会有这么两个问题
  • 1.ArrayList和Array的的区别是什么?
它和数组区别一个是封装了基本的操作,我们只需要调用API,而不需要去实现一个个操作(就是省事了)
还有一个最大的区别就是ArrayList支持动态扩容,不需要事先指定大小,当内存不够时自动扩容为1.5倍
  • 2.什么时候使用ArrayList,什么时候使用Array?
1.ArrayList不能存储基本的护具类型,比如int,需要封装成integer,封装时有一定的消耗,如果你存储基本数据类型,请选用数组
2.如果大小事先已知,且操作简单,可以使用ArrayList
3.总结一下,基本的开始使用ArrayList就好,省时,省力,如果是非常底层的开发,对性能要求非常严格,数组就是首选

    推荐阅读