Java数据结构与Java算法学习Day03---线性表(简略笔记记录)

目录

一、线性表 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

双向链表的指向是双向的。双向箭头。Java数据结构与Java算法学习Day03---线性表(简略笔记记录)_第1张图片 

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

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

3.4快慢指针 57

3.4.1中间值问题 57

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

原理部分在PPt P27

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

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

思路:

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

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

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

Java数据结构与Java算法学习Day03---线性表(简略笔记记录)_第2张图片

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

3.4.3有环链表入口问题  60

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

Java数据结构与Java算法学习Day03---线性表(简略笔记记录)_第3张图片

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

3.5循环链表 61

 Java数据结构与Java算法学习Day03---线性表(简略笔记记录)_第4张图片

代码部分的实现查看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

Java数据结构与Java算法学习Day03---线性表(简略笔记记录)_第5张图片

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

原理实现的分析:68

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

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

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

Java数据结构与Java算法学习Day03---线性表(简略笔记记录)_第6张图片

 

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

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

代码的实现:71

代码在/test/ReversePolishNotationTest中

3.8队列 72、73

你可能感兴趣的:(数据结构与算法,数据结构,学习,链表,java,算法)