肥宅钓鱼网
当前位置: 首页 钓鱼百科

程序员数据结构心法(程序员必备数据结构)

时间:2023-06-13 作者: 小编 阅读量: 1 栏目名: 钓鱼百科

数据结构和算法是每个程序员都应该掌握的技能。特意给大家总结了一份《数据结构和算法的知识大纲》,希望对大家有帮助。更多架构师之路干货文章,已在路上,稍后就到!

数据结构和算法是每个程序员都应该掌握的技能。

特意给大家总结了一份《数据结构和算法的知识大纲》,希望对大家有帮助。

一:内容概述

本知识大纲主要内容包含:

1:数组

有序和无序数组的操作、二分法查找、存放对象、大O表示法

2:栈

线形表、栈、栈的操作、栈的实例、后缀表达式(包括转换和计算)

3:队列

队列、队列的实现、循环队列、双端队列、优先级队列

4:链表

链表、单链表、双端链表、用链表实现栈和队列、有序链表、双向链表

5:递归算法

递归、阶乘、分治算法、斐波那契数列、汉诺塔、背包问题、归并排序

6:排序算法

冒泡、选择、插入法、希尔、快速、基数、对象排序

7:二叉树

二叉树概念和性质、二叉树的实现、哈夫曼编码、哈夫曼树、哈夫曼算法、使用哈夫曼算法来实现压缩和解压的功能

8:红黑树

概念和特征、红黑树的规则和修正、红黑树的旋转、红黑树的实现

9:2-3-4树

概念和规则、2-3-4树的实现、2-3-4树和红黑树的关系和转换规则

10:B树

概念和特性、B树的高度、B树的实现、B树的变形

11:堆

概念和特点、堆的实现、堆排序

12:哈希表

概念和优缺点、Hash函数的构建、冲突解决(开放地址法和链地址法)、Hash化字符串

13:图

概念和基本术语、深度和广度搜索、最小生成树、有向图的拓扑、有向图的连通、Warshall算法、带权图的最小生成树、普里姆算法、最短路径问题、迪杰斯特拉算法、弗洛伊德算法

二:Java数据结构和算法知识大纲

数组

数组是什么

对数组的插入、删除、查找操作

无序数组

重复放值

不重复放值

有序数组

二分法查找

存放对象

大O表示法

简单排序

冒泡排序

选择排序

插入法排序

对象排序

线性表

线性表概念

线性表和数组的关系

什么是栈

栈的基本操作

push:压栈或入栈操作

pop:弹栈或出栈操作

peek:查看栈顶数据,而不弹出数据,也就是不做出栈操作

栈的基本实现

栈的应用实例

字符串倒序

括号(小、中、大)匹配

计算算术表达式

后缀表达式

什么是后缀表达式,也称波兰逆序表达式

如何把中缀表达式转换成后缀表达式

计算后缀表达式求值

栈的效率

队列

什么是队列(Queue)

队列的基本操作

insert:在队尾插入数据

remove:从队头移走数据

peek:查看队头的数据

循环队列

队列的基本实现

队列的效率

双端队列

优先级队列

优先级队列就是数据项按照关键字排好顺序的队列

优先级队列的实现

优先级队列的效率

链表

什么是链表(Linked List)

链表和数组

链表的基本操作

向链表中插入数据

从链表中移走数据

查看链表中所有的数据

查找指定链结点

删除指定链结点

单链表

单链表的基本实现

单链表的效率

双端链表

双端链表是,不仅仅记录着开始结点,同时也记录着结束结点

双端链表的实现

使用链表来实现栈和队列

有序链表

有序链表就是链表中的数据是排好顺序的

有序链表的实现

有序链表的效率

使用有序链表来实现插入排序

双向链表

什么是双向链表

双向链表的实现

递归算法

什么是递归

递归示例:阶乘

理解递归

递归示例:斐波那契数列

汉诺塔(河内塔)问题

背包问题

归并排序

高级排序

希尔排序

快速排序

基数排序

二叉树

树的基本知识

二叉树的概念和理解

二叉树的性质

二叉搜索树

二叉搜索树是什么

二叉搜索树的查找、插入、遍历、查找最大最小值和删除操作

二叉搜索树操作的效率

用数组来表示树

哈夫曼(Huffman)编码

哈夫曼树

什么是哈夫曼树

哈夫曼树的构造方法——Huffman算法

哈夫曼压缩的编码部分的实现步骤

哈夫曼压缩的解码部分的实现步骤

红黑树

平衡与非平衡树

红黑树是什么以及特征

红黑树的规则

红黑树的修正手段

红黑树的旋转

红黑树的插入算法

红黑树的节点删除

红黑树的删除算法

删除步骤后的调整步骤

红黑树的效率

了解其它平衡树:AVL

2-3-4树

多叉树

2-3-4树是什么

2-3-4树的数据组织规则

2-3-4树的搜索算法

2-3-4树的插入算法

2-3-4树的节点删除

2-3-4树和红黑树

2-3-4树转换成红黑树的规则

2-3-4树的效率

B树

B树是什么

回忆磁盘存取数据的知识

B树的特性

B树的高度

B树的搜索算法

B树的插入算法

B树的删除算法

B 树

B 树是什么

B 树和B树的特性差异

B 树的优势

B 树的磁盘读写代价更低

B 树的查询效率更加稳定

B 树支持基于范围的查询

Hash表

Hash表是什么

Hash表的优缺点

什么是Hash化

Hash函数的基本过程

常用的构造Hash函数的方法

直接寻址法

数字分析法

平方取中法

折叠法

随机数法

除留余数法

Hash冲突

Hash冲突的解决

开放地址法

链地址法

设计好的Hash函数

Hash化字符串

Hash化的效率

堆是什么

堆的特点

堆的插入算法

堆的删除算法

堆的查找

堆的效率

堆排序

堆排序的基本思想

堆排序的效率

图(不带权)

图是什么

图的基本术语

在程序中表示图

图的搜索(遍历),算法并代码示例

深度优先

广度优先

最小生成树,算法并代码示例

有向图的拓扑排序,算法并代码示例

有向图的连通性,算法并代码示例

Warshall算法,算法并代码示例

带权图

什么是权

带权图的最小生成树

普里姆算法,代码示例

最短路径问题

迪杰斯特拉算法,代码示例

弗洛伊德算法,代码示例

稀疏图和稠密图

图的效率

可惜头条没法给大家发放资源,先就看看知识大纲吧!

如果你觉得本系列文章还不错,能够给你一些启发和思考的话,请关注、点赞、收藏加转发,让更多的朋友加入到我们的行列,谢谢啦!

更多架构师之路干货文章,已在路上,稍后就到!

    推荐阅读
  • 冬季果树种植方法及注意事项(冬季果树种植方法及注意事项简单介绍)

    一般在整形期的果树,修剪主要在春、夏季新梢生长期及未木质化前进行,前期以摘心、短截、放梢、为主,后期以短截、平拉枝为主,以促早花早果;正式结果树,则以冬夏剪为主,冬季以疏剪干枝、病虫枝、绞靠枝、徒长枝、过密枝为主,夏季以摘心、疏剪徒长枝、平拉结果母枝为主,以平衡营养生长和生殖生长,促丰产、稳产。

  • 84消毒液洗彩色衣服怎么配比(你了解吗)

    接下来我们就一起去了解一下吧!84消毒液洗彩色衣服怎么配比84消毒液不能用于彩色衣服,可能会有褪色作用,只有白色的棉、麻、涤纶材质可以氯漂的衣服才能用84消毒液。使用84消毒液须注意:切勿用于丝绸、毛、尼龙、皮革、油漆表面;切勿用于铝、铜、碳钢制品,适用于不锈钢器具消毒;餐饮具,瓜果蔬菜消毒后,用清水洗净;对于彩色织物可能有褪色作用,请先在隐蔽处试用;建议使用时带手套,避免接触皮肤。

  • 初中英语重点短语和句型总结(初中英语短语总共15组)

    本文总结了中考英语重点短语,含中英文例句。Helosthimselfinthehotdance.他沉醉于热舞之中。做好准备Thestudentsarenervouslygettingreadyforthefinaltest.学生们正紧张地准备期末考试。

  • 国庆十一成都旅游攻略 成都国庆好去处

    十一国庆马上就要来了,当大家在为火车票的购买而担忧时,你们想好了要去的那个城市有什么好玩的吗?十一成都旅游去哪比较合适呢?别着急,小编帮大家整理了2021十一成都旅游攻略与经典介绍,赶紧来看下吧!

  • 午餐前青汁打卡攻略(打卡芹菜汁第一天)

    下面希望有你要的答案,我们一起来看看吧!午餐前青汁打卡攻略最近经常看到西芹汁的功效,我也来试试!今天是喝西芹汁的第1天,那个味道啊,满屋都是芹菜味,皱着眉毛干了一杯,瞬间感觉川子纹都出来了~~~想要喝西芹汁J重的姐妹咱们一起来见证效果吧!有在坚持打卡的姐妹来说说你们的变化吧!

  • 张元杀张煌言是哪部电影 张煌言 电影

    张煌言的学生王青凤、侍童杨冠玉那夜被徐元的部下、暗藏的抗清志士史炳搭救,死里逃生,得知张煌言死讯,带同他的残部一起找徐元寻仇。

  • 云南糊辣鱼的做法(糊辣鱼怎么做)

    以下内容希望对你有帮助!云南糊辣鱼的做法主料:草鱼500克,绿豆芽100克,芹菜100克,青蒜50克,香菜20克,芝麻5克。调料:辣椒50克,豆瓣酱25克,花椒10克,姜25克,大蒜25克,料酒10克,盐3克,味精5克,鸡精5克,胡椒粉2克,酱油10克,葱汁3克,姜汁2克,淀粉(玉米)12克,辣椒油200克,植物油100克。

  • 苹果xsmax有nfc功能吗(苹果xsmax有NFC功能吗?)

    演示机型:Iphonexsmax系统版本:iOS14.4苹果xsmax有nfc功能。但是nfc模块仅支持applepay,还没有对第三方开发者开放接口。iPhoneXSMax支持千兆级LTE,具备4x4MIMO和LAA技术,支持802.11ac无线网络,具备2x2MIMO技术,支持读卡器模式的NFC。

  • 油爆孜然虾教程(油爆孜然虾做法)

    油爆孜然虾教程油爆孜然虾的用料:虾500克、盐适量、孜然粒3g、糖5g、莴笋300g、香油2滴、料酒10ml、葱适量、姜丝适量。虾洗干净,去皮。剥虾壳,从第二节到第三节中间下手,非常好剥还不扎手,取虾线,不要因为麻烦就不取虾线,这个影响口感还不美观。虾剥好加入料酒腌制一下,可以去腥味。把葱花,姜丝,孜然粒爆香。加入虾,开始炒,全程不加一点水。虾全红了加入莴笋继续翻炒。淋香油和盐,就可以出锅了。