栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java中的数据结构:数组与链表的区别

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java中的数据结构:数组与链表的区别

数组的定义

数组(Array)是有序的元素序列。 若将有限个类型相同的变量的集合命名,那么这个名称为数组名。组成数组的各个变量称为数组的分量,也称为数组的元素,有时也称为下标变量。用于区分数组的各个元素的数字编号称为下标。数组是在程序设计中,为了处理方便, 把具有相同类型的若干元素按有序的形式组织起来的一种形式。 这些有序排列的同类数据元素的集合称为数组。
数组是用于储存多个相同类型数据的集合。

数组的特性

数组分配在内存上要求必须是连续的数组在在创建时要申请创建的内存大小,如果使用量很小,就会造成内存的浪费。插入或删除的效率低,由于要求内存上是连续的,所以添加或删除的元素后面的所有元素都要移动。数组的读取效率非常高,因为是连续的,所以能知道每个元素在内存上的位置。 链表的定义

链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。 相比于线性表顺序结构,操作复杂。由于不必须按顺序存储,链表在插入的时候可以达到O(1)的复杂度,比另一种线性表顺序表快得多,但是查找一个节点或者访问特定编号的节点则需要O(n)的时间,而线性表和顺序表相应的时间复杂度分别是O(logn)和O(1)。

链表的特性

链表分配在内存上可以使非连续,非顺序的 每个元素都记录着它下一个元素的地址,双向链表每个元素记录着他的上一个元素和下一个元素。插入或删除效率高,如:原先AC是一个链表结构,这时要在AC中间插入元素B,他(B)只要在元素(A)拿到下一个元素(C)的地址,让元素A记录自己B为下一个元素,B记录C为它的下一个元素即可完成链表。链表查询效率低,因为在地址上是不连续的,只能从标的第一个元素一个一个的往下找。不用提前申请链表的大小

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/777033.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号