数据结构和概述集合

数据结构

1、线性表

(数组)存储区间是连续的,占用内存严重,故空间复杂度很大。但数组的二分查找(前提是必须有序)时间复杂度小,为O(1);
数组的特点是:

  • 寻址容易(arr[n]=arr[0]+n*每个元素的长度,时间复杂度为O(1))
  • 插入和删除困难(可能会引发一半以上的数据元素移动,时间复杂度为O(n));
  • Java中的数组是定长的,如果需要变长则需要自行编程实现

2、链表

存储区间离散(数据不是连续存放的),占用内存比较宽松,故空间复杂度很小,但操作元素的时间复杂度很大,达O(N)。
链表的特点是:

  • 寻址困难(可能需要通过遍历的方式查找元素,时间复杂度为O(n))
  • 插入和删除容易(不需要引发元素的移动,仅仅只是进行地址的拷贝,时间复杂度为O(1))。

概述集合

  • 集合只能存放对象。比如你存一个 int 型数据 1放入集合中,其实它是自动转换成 Integer 类后存入的(装箱操作),Java中每一种基本类型都有对应的引用类型
  • 集合存放的是多个对象的引用,对象本身还是放在堆内存中
  • 集合可以存放不同类型,不限数量的数据类型。定义集合变量时如果不指定数据类型,则默认数据
    类型为Object

数组和集合的比较

针对Java中的数组定长,Java提出了集合框架,实现了一种变长存储数据的容器—集合【容积和当前元素个数】
数组不是面向对象的,存在明显的缺陷,集合弥补了数组的缺点,比数组更灵活更实用,而且不同的集
合框架类可适用不同场合。如下:

  • 数组能存放基本数据类型和对象,而集合类存放的都是对象的引用,而非对象本身
  • 数组容量固定无法动态改变,集合类容量动态改变
  • 数组无法判断其中实际存有多少元素,length只告诉了数组的容量,而集合的size()可以确切知道元素的个数
  • 集合有多种实现方式和不同适用场合,不像数组仅采用顺序表方式
  • 集合以类的形式存在,具有封装、继承、多态等类的特性,通过简单的方法和属性即可实现各种复杂操作,大大提高了软件的开发效率

猜你喜欢

转载自blog.csdn.net/Lecheng_/article/details/113954896