Java数据结构与Java算法学习Day03---线性表(简略笔记记录)
创始人
2024-03-18 07:30:40
0

目录

一、线性表 38

二、顺序表 39

三、链表 45

3.1单向链表 46、47、48

3.2双向链表 49

3.3链表反转 (面试中高频题目) 56

3.4快慢指针 57

3.4.1中间值问题 57

3.4.2单向链表是否有环问题 58

3.4.3有环链表入口问题  60

3.5循环链表 61

3.6约瑟夫问题 62 

3.7栈概念 65

3.7.1栈的了解 65

3.7.2栈的代码实现 66

3.7.3括号匹配问题(栈的应用) 68

3.7.4逆波兰表达式求值问题 70

3.8队列 72、73


一、线性表 38

二、顺序表 39

三、链表 45

解决问题:解决顺序表查询增删效率比较慢的问题。

3.1单向链表 46、47、48

头结点:不存储任何数据,只是能够找到下一个数据即可。

3.2双向链表 49

双向链表的指向是双向的。双向箭头。 

3.3链表反转 (面试中高频题目) 56

本部分的代码,是在原来linear/LinkList基础上进行增加的。添加reverese方法和一个结点处理。

3.4快慢指针 57

3.4.1中间值问题 57

该部分在代码\test\FastShowTest中。

原理部分在PPt P27

3.4.2单向链表是否有环问题 58

使用快慢指针判断链表是否有环问题。

思路:

有环:快慢指针会有相遇的那一刻

无环:快慢指针不可能有相遇的那一刻

有环和无环的判断:有环的最后一个结点指向了前面的结点。

 本部分实现的代码:在/test/CircleListCheckTest中

3.4.3有环链表入口问题  60

该部分也涉及使用到快慢指针 

本部分代码的实现在/test/CircleListTest中。判断的方法名称:getEntrance

3.5循环链表 61

 

代码部分的实现查看ppt P36

3.6约瑟夫问题 62 

本部分代码在/test/JosephTest中

主要的内容参考ppt P37。

3.7栈概念 65

3.7.1栈的了解 65

本部分看ppt P40

3.7.2栈的代码实现 66

代码在/linear/Stack中

其他部分的实现代码:67

3.7.3括号匹配问题(栈的应用) 68

原理实现的分析:68

 代码:在/test/BrancketsMatchTest中实现代码 69

3.7.4逆波兰表达式求值问题 70

对于逆波兰表达式的解释:70

 

1、ab:在操作数后面添加+

2、abc-+:先bc操作数进行-处理,然后整体的结果a和bc处理后的结果做+

代码的实现:71

代码在/test/ReversePolishNotationTest中

3.8队列 72、73

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...