一篇文章带你入门Java数据结构
1、逻辑结构和物理结构
逻辑结构:
集合: 数据与数据之间没有任何关系
线性: 一对一关系
树型: 一对多关系
图型: 多对多关系
物理结构:
顺序结构(数组):
链式结构(链表):
2、顺序结构,链式结构,栈,队列,二叉树
顺序结构:
可扩容数组,底层用数组实现,顺序排列,标号连续,内存空间连续
优缺点:
查询速度快,在中间频繁的增删操作慢,碎片内存空间利用不到
链式结构:
底层用节点(Object date 和 前后节点或者下一个结点的引用)
内存顺序连续,但是在物理存储空间不连续
优缺点:
频繁的增删操作速度快,查询速度慢,综合起来没有ArrayList好,空间利用率好,可以利用到物理内存中的碎片空间
栈:
可以用数组或者链表实现,先进后出原则
方法:
push()压栈 和 pop()弹栈
队列:
可以用数组或者链表实现,先进先出原则
二叉树
普通二叉树:
满二叉树:
完全二叉树:
k - 1 层是满二叉树,k 层从左到右是连续的
平衡二叉树:
左右子树高度相差不超过1
排序二叉树:
左子树的值都小于根,右子树的值都大于等于根
二叉树的遍历:
先序遍历 - 根左右
中序遍历 - 左根右
后序遍历 - 左右根
总结
本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!
相关文章
Eclipse 2020-06 汉化包安装步骤详解(附汉化包+安装教程)
这篇文章主要介绍了Eclipse 2020-06 汉化包安装步骤(附汉化包+安装教程),本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-08-08Spring处理@Async导致的循环依赖失败问题的方案详解
这篇文章主要为大家详细介绍了SpringBoot中的@Async导致循环依赖失败的原因及其解决方案,文中的示例代码讲解详细,感兴趣的可以学习一下2022-07-07Spring注解@Value在controller无法获取到值的解决
这篇文章主要介绍了Spring注解@Value在controller无法获取到值的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11
最新评论