美文网首页
数据结构与算法-数据结构(数组)

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

作者: Wangthirteen | 来源:发表于2018-12-05 16:54 被阅读1次

    数组是最基本的数据结构之一,当然我们每天也都在使用数组,那么你知道数组的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就好,省时,省力,如果是非常底层的开发,对性能要求非常严格,数组就是首选

    相关文章

      网友评论

          本文标题:数据结构与算法-数据结构(数组)

          本文链接:https://www.haomeiwen.com/subject/eidwcqtx.html