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

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

作者: 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就好,省时,省力,如果是非常底层的开发,对性能要求非常严格,数组就是首选

相关文章

  • 数据结构:数组

    00数据结构与算法分析:大纲01数据结构:数组02数据结构:链表03数据结构:栈03数据结构:队列 数组 数组是一...

  • 重温:数据结构与算法 - 03数组

    数据结构与算法之美 - 数组 数据结构与算法之美-学习大纲 什么数组? 数组是一种 线性表 数据结构。它用一组 连...

  • Hash算法

    数据结构与算法分析:大纲数据结构:数组算法:hash算法算法:排序算法Java实现 1 Hash算法? 将任意长度...

  • 数据结构与算法分析:大纲]

    00数据结构与算法分析:大纲01数据结构:数组02数据结构:链表03数据结构:栈03数据结构:队列 本系列课程主要...

  • 数据结构与算法 - 查找

    数据结构与算法系列文章数据结构与算法 - 时间复杂度数据结构与算法 - 线性表数据结构与算法 - 树形结构数据结构...

  • 思维导图之数据结构+算法

    数据结构+算法 = 程序 数据结构比较 参考文章 数据结构与算法数据结构与算法(java)

  • 工作消失而面试却长存的算法与数据结构

    工作消失而面试却长存的算法与数据结构: 优秀的算法和数据结构被封装到了Java的集合框架之中 数据结构考点: 数组...

  • 数据结构与算法学习开篇

    数据结构与算法知识图谱 20个最常用的、最基础数据结构与算法 10个数据结构:数组、链表、栈、队列、散列表、二叉树...

  • 数据结构与算法 - 树形结构

    数据结构与算法系列文章数据结构与算法 - 时间复杂度数据结构与算法 - 线性表数据结构与算法 - 树形结构 目录 ...

  • Android高级开发面试题

    一、Java 基础相关 1.1 数据结构与算法 1.1.1 常用的数据结构有哪些? 1.1.2 数组 (1).如何...

网友评论

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

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