一篇文章带你入门Java数据结构

1、逻辑结构和物理结构

逻辑结构:                                                                                                                   

集合: 数据与数据之间没有任何关系

线性: 一对一关系

树型: 一对多关系

图型: 多对多关系                                                                                                               

物理结构:

顺序结构(数组):                                                                                                             

链式结构(链表):

2、顺序结构,链式结构,栈,队列,二叉树

顺序结构:

可扩容数组,底层用数组实现,顺序排列,标号连续,内存空间连续                 

优缺点:

查询速度快,在中间频繁的增删操作慢,碎片内存空间利用不到

链式结构:

底层用节点(Object date 和 前后节点或者下一个结点的引用)                         

内存顺序连续,但是在物理存储空间不连续                                                              

优缺点:

频繁的增删操作速度快,查询速度慢,综合起来没有ArrayList好,空间利用率好,可以利用到物理内存中的碎片空间

栈:

可以用数组或者链表实现,先进后出原则                                                                       

方法:

push()压栈 和 pop()弹栈

队列:

可以用数组或者链表实现,先进先出原则

二叉树

普通二叉树:

一篇文章带你入门Java数据结构_第1张图片

满二叉树:

一篇文章带你入门Java数据结构_第2张图片

完全二叉树:

k - 1 层是满二叉树,k 层从左到右是连续的

一篇文章带你入门Java数据结构_第3张图片

平衡二叉树:

左右子树高度相差不超过1

一篇文章带你入门Java数据结构_第4张图片

排序二叉树:

左子树的值都小于根,右子树的值都大于等于根

二叉树的遍历:

先序遍历 - 根左右

中序遍历 - 左根右

后序遍历 - 左右根

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!           

你可能感兴趣的:(一篇文章带你入门Java数据结构)