数据结构分类:
列表 型---1.数组 2.链表 3.队列 4.栈数组【详解】
开辟一片连续的空间,将元素依次放入其中;
数组的好处:可以进行随机访问,只需要一个下标就可以访问到该元素;但插入和删除会比较耗费时间,插入和删除操作都需要将之后的元素进行整体的移动,腾出空间来进行对应的操作。
链表【详解】
每一个节点通过 next 值链接起来;
查找元素耗费时间O(n),需要一个计数器,从表头开始顺着 next 依次往后找,数到第 n 个就可以将第 n 个元素取出来;但插入和删除不会耗费时间,插入操作只需要将插入前后的两个集成打断,再将插入的元素连接起来即可;删除操作只要将要删除的元素跳过即可,
队列【详解】
不支持随机访问,只支持 push 和 pop 操作,push 将元素放进去,pop 将元素拿出来,拿出的顺序是先进先出
栈【详解】
不支持随机访问,只支持 push 和 pop 操作,push 将元素放进去,pop 将元素拿出来,拿出的顺序是先进后出
树 型---1.二叉树 2.搜索树 3.优先队列
二叉树 【详解】
每个节点最多有两个孩子节点,分为左孩子节点和右孩子节点;
二叉树要点:
1.二叉树具有唯一的根节点;
2.二叉树中每个节点最多有两个孩子,每个节点最多有一个父亲节点;一个孩子也没有的叫做叶子节点
3.二叉树具有天然的递归结构【每个节点的左子树也是二叉树、每个节点的右子树也是二叉树】
搜索树【详解】
1.二分搜索树是二叉树
2.二分搜索树的每个节点的值:大于其左子树的所有节点的值且小于其右子树的所有节点的值
3.二分搜索树的每个子树也是二分搜索树
4.存储的元素必须具有可比较性【存储自定义数据类型,必须自定义好数据的比较方式】
优先队列【详解】
普通队列:先进先出,后进后出
优先队列:出队顺序和入队顺序无关;和优先级相关;
总结:
图 型---1.无向图 2.有向图
无向图
每个节点之间没有方向,可以从 a--b ,也可以 b--a ,但每个边有权重
有向图
所有的边都是单向的,只能从 a--b,b不能到 a,要让 b 到 a 则必须再加一条边
有向无环图
可以描述任务之间的层级关系,
相关算法:深度优先遍历【能够看到图的每个节点】
广度优先遍历【走迷宫,识别联通块】
拓扑排序【有很多先后的依赖关系,先做哪一个】
最短路径/最小生成树
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)