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

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...