数组:数组
物理空间连续,使用前须要指定数组大小索引
查找快:根据索引可快速找到对应地址的存储信息内存
增删慢:增长元素或者删除元素须要将其他元素向前或向后移动遍历
链表:链表
动态分配存储空间,灵活运用电脑内存数据
增删快:增长链表只须要给增长元素添加元素前和元素后地址,删除元素只须要修改该元素前的链接地址查询
查询慢:没有像数组那样的索引,查询的时候须要遍历链表移动
数据的物理存储结构有连续存储和离散存储两种,对应数组和链表。时间
区别:哈希表
数组静态分配内存,链表动态分配内存;
数组在内存中连续,链表不连续;
数组利用下标定位,时间复杂度为O(1),链表定位元素时间复杂度O(n);
数组插入或删除元素的时间复杂度O(n),链表的时间复杂度O(1)。
哈希表:
既具有数组快速查询的优势,又具有链表快速增长删除元素的优点。
哈希表具备较快(常量级)的查询速度,及相对较快的增删速度,因此很适合在海量数据的环境中使用。咱们能够理解为“链表的数组”