当前位置: 首页 > news >正文

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

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

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

相关文章:

  • 浙江省建设监理协会网站/网络销售好做吗
  • 湘潭网站优化/武汉seo公司排名
  • 网站设计制作花多少钱/竞价推广怎样管理
  • 网站怎么做用qq登录接入/网络营销期末考试试题及答案
  • 做网站卖机械/互联网推广有哪些方式
  • 网站建设服务支持/今日头条新闻最新疫情
  • 智工教育:注册计量师一级和二级的科目一样吗?
  • 计算机毕业设计Java的音乐网站管理系统(源码+系统+mysql数据库+lw文档)
  • 三、CSS基础-元素显示模式 行元素,块元素,行内块元素
  • Springboot旅游度假村管理系统34q0n计算机毕业设计-课程设计-期末作业-毕设程序代做
  • 基于MCMC的交通量逆建模(Matlab代码实现)
  • Dcoker入门,小白也学得懂!
  • JS 解构赋值
  • 三、内存管理 (二)虚拟存储器
  • R语言确定聚类的最佳簇数:3种聚类优化方法
  • 威伦触摸屏TK6060IP简单例子
  • 力扣(LeetCode)134. 加油站(C++)
  • 【Python】《Python编程:从入门到实践 (第2版) 》笔记-Chapter1-起步