12.9_黑马数据结构与算法笔记Java

news2025/2/4 23:58:09

目录

057 多路递归 e03 杨辉三角2

thinking:二维数组的动态初始化?

057 多路递归 e03 杨辉三角3

058 链表 e01 反转单向链表1

058 链表 e01 反转单向链表2

058 链表 e01 反转单向链表3 递归

058 链表 e01 反转单向链表4

为什么是returnn1呢?也就是新头,而不是一整个链表?

058 链表 e01 反转单向链表5

058 链表 e02 根据值删除节点1

058 链表 e02 根据值删除节点2

058 链表 e03 删除倒数节点1 递归

058 链表 e03 删除倒数节点2

058 链表 e04 有序链表去重1

058 链表 e04 有序链表去重2 递归

058 链表 e05 有序链表去重1 递归

058 链表 e05 有序链表去重2

058 链表 e06 合并有序链表1

搞清楚: p1 = p1.next & p1.next=p2.next

058 链表 e06 合并有序链表2

058 链表 e07 合并多个有序链表

058 链表 e08 查找链表中间节点

058 链表 e09 判断回文链表1

058 链表 e09 判断回文链表2


057 多路递归 e03 杨辉三角2

thinking:二维数组的动态初始化?

Java 中的一维数组以及二维数组(8千字零基础超全详解)_java一维数组和二维数组-CSDN博客

057 多路递归 e03 杨辉三角3

058 链表 e01 反转单向链表1

不断创建新的节点,相当于复制黏贴一份链表了

说明可以单独访问ListNode里的val或者单独访问ListNode里的next。 

a:设置新链表第一个节点的value值,不用设置指针。

b:旧链表的第一个节点

c:创建一个ListNode,值为旧链表第一个节点的value,指向:新链表的头部;并且,更新新链表的头部。这里左侧的n1代表一个节点,是包含vaule值和指向的节点,右侧的n1只有指向的含义。(右侧的n1也可以理解成,现在新建的节点和n1指向的方向相同。)

d:旧链表中的元素变成下一个旧链表元素

直到旧链表所有的元素插入完毕。

       和这里很相似,创建了一个新节点后,再让头部指向新的节点。因此,刚刚案例中,所谓的更新,也可以理解成让n1指向新的节点 ,也就是让旧的节点指向新的节点(1指向2),因为1先插入,2后插入。

058 链表 e01 反转单向链表2

first.next 指向head,其中first.next是指指针。就是这个指针指向head

head更新为first=将first的值赋值给head

058 链表 e01 反转单向链表3 递归

 p.next 为5 这个东西,5.next 是这个东西的指向。所以就是p.next.next

让4指向null,而不是像原先一样还指向5,这样不会造成死循环

058 链表 e01 反转单向链表4

将旧链表的第二个节点移动到新链表的头部

o2.next 指针含义:o2指向o3

那现在让o1.next =o2.next 就是说,让o1像o2一样指向o3,也就是说,o2断开了 。

为什么是returnn1呢?也就是新头,而不是一整个链表?

       因为它每一次传进来的都是一个元素,那就只对这个元素进行加工,并且之前还设置了toString方法,就是为了拼接这些元素的。 

-----------------------------------------------第二天想法--------------------------------------------------------------

噢我好像知道为什么直接返回n1就可以了,我一开始以为,返回n1就只返回一个元素,原来,返回n1就返回n1以及n1后面元素组成的这一条链子。!! 

------------------------------------------------------------------------------------------------------------------------------

058 链表 e01 反转单向链表5

和方法2类似,方法2是面向对象,方法5是面向过程

n1 = o1: n1做了o1该做的事情,或者说o1的责任赋予给n1了。于是乎

o1 = o2 : o1就要回到旧链表中,那它要回到哪里去呢?它要回到的位置就是o2帮他记录的位置。 

058 链表 e02 根据值删除节点1

p1要删除节点的上一个指针

p2要删除节点的指针

理解:

p1.next = p2.next  

是指p1的指针等于p2的指针,而指针的作用是用于指明方向,因此意思为:p1指向的位置是p2指向的位置

p2 = p2.next 

这里的右边是指 p2的下一个节点,整句话的意思是:将p2的下一个所有东西赋予给p2

也意味着p2向后平移了一位(假设现在链表不动,是指针在动)

优化:要不是原来的方案:旧的p2指向的下一位;或者新的方案:删除后,p1指向的下一位

058 链表 e02 根据值删除节点2

返回 p的下一个节点的指针以及值 

针对p.next =removeElements(p.next,val)这一块,左边的含义是:自身的指针要更新一下,不然一直在原地不动。那,需要更新一下的话,那要更新成什么样子的呢?也就是说,这个指针要被赋予的值是什么呢?这个值从哪里来呢?就从右边来的。p.next :下一个节点开始删,removeElements() :删完之后的那个链表,作为我当前节点的链表。

就拿这个做例子,数组是:1,2,6,3,6

现在进行到:1,2,6,3到1,2,6这一步

p.next: 指针现在指着3 那删除之后,应该移动到6 (从下一个节点开始删)

removeElements() :1,2,6(删完之后的那个链表,作为我当前节点的链表)

我们再看,它的方法返回的是 3->null 这样的,所以挺有那感觉。

呜呜尽力了,只能先理解到这里了。

--------------------------------------第二天的思路-------------------------------------------------------

右侧:更新完了。左侧:那就在你更新完之后的下一个节点开始。

----------------------------------------------------------------------------------------------------------------

058 链表 e03 删除倒数节点1 递归

返回 0 代表倒数第0个

返回1 代表倒数第1个

返回2 代表倒数第2个 

如果p==null的话,返回0。也就是说,代表null在倒数第0个位置 

左边和右边的数字分别代表:每个节点,每个节点的下一个节点的倒数位置

如果,传过来的n等于nth(nth:每个节点的下一个节点的倒数位置) 

举个例子:p=3,那nth就是它的下一个节点的倒数位置,也就是4的倒数位置,4的倒数位置是2。现在要删掉4。因此让p=3指向p=5。

对于第一个节点来说,没有上一个节点了。但我们之前处理的办法都是:处理这个节点的下一个节点。因此,节点1 知道节点2 的位置,但是没有人知道节点1在哪里。因此加一个哨兵。

058 链表 e03 删除倒数节点2

方法二:设置两个指针,先让p2走n+1步。之后再让p1,p2一起走,p2走多少步,p1就走多少步,要保持p1和p2的距离保持n+1,直到p2走到null为止。这样,p1的下一个位置就是我要删除的元素。

这里的n=2,是指我要删除的是倒数第二个位置的元素,也就是4这个元素。

 p1.next :p1的指针

p1.next.next:p5

=:让p1的指针指向p5

058 链表 e04 有序链表去重1

为p2赋值 

p1.next = p2.next :p1的指针方向现在改为p2的指针方向。因此,也代表p1向后平移一位。

058 链表 e04 有序链表去重2 递归

方法二:若第一个节点和第二个节点的取值相同的时候,不要第一个节点,要第二个节点。

2和3作比较的时候,若不相同,返回我(2),并且next更新为下一个节点,也就是p=3 

右侧:更新完了。左侧:那就在你更新完之后的下一个节点开始。

好像前面那道题也是差不多这样的意思。 哎哟,好像明白了。

058 链表 e05 有序链表去重1 递归

058 链表 e05 有序链表去重2

058 链表 e06 合并有序链表1

搞清楚: p1 = p1.next & p1.next=p2.next

 第一个是:p1指向  p1下一个指向   的值,也就是p2。也就是指针往后平移一位

第二个是:p1的指针等于p2的指针,也就是 p2指向的方向现在也变成了p1指向的方向,也就是说p1指向了p3

058 链表 e06 合并有序链表2

4.next在8和9之间选择。也就是4.next是这个mergeTwoLists方法得出的结果

 

058 链表 e07 合并多个有序链表

先把多个链表拆分,最后再合成变成一个数组。 

前者:多路递归较多体现

后者:单路递归较多体现,并没有拆分为两个或以上问题,只是相同的问题,但是问题规模减小;了。 

058 链表 e08 查找链表中间节点

奇数情况。

偶数情况。

不管奇数偶数,都是慢指针走一步,快指针走两步。直到快指针走到null或者走到null的前一位,就停止,这个时候,慢指针指的就是中间位置。 

p2 != null要写在前面,因为如果这个条件不成立的话,就不会执行第二个条件了,它的执行是有顺序的。

058 链表 e09 判断回文链表1

噢我好像知道为什么直接返回p1就可以了,我一开始以为,返回p1就只返回一个元素,原来,返回p1就返回p1以及p1后面元素组成的这一条链子。!! 

058 链表 e09 判断回文链表2

使分开的方法合并到一起 

 

方法二:

既找到中间点,同时也让前半部分的元素进行反转。

以上这张图是之前的案例的解释 

部分代码详解:

ListNode o2 =o1.next: 旧头的第二个位置命名为o2

o1.next=n1: o1这个旧头的指针指向n1这个新头,也就是o1所在的元素移动到新队伍当中去了,(看3搬移那里)。

n1 = o1: o1要把责任交给n1了

o1 =  o2:o1要回去旧队伍了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1299877.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

递归的两个特点、典型案例----汉诺塔问题

一、递归的两个特点 1、要自己调用自己 2、递归函数里要有结束条件。 二、汉诺塔问题 有三根柱子,现在在一根柱子上,从下往上,按照大小顺序摞着很多盘子。现在要把这些盘子全部放到另一根柱子上,且盘子依然按照从大到小顺序摞着…

触手可及的便携CD播放器,随时享受音乐乐趣,山灵EC Mini上手

如今做发烧级实体CD播放器的国产品牌越来越少了了,最近我尝试了一款山灵的便携式CD播放器,感觉它做得很有味道。在CD机领域,山灵技术积累的不错,像是这款EC Mini,不论设计还是体验都很出色,既能够满足实体C…

基于Java SSM框架实现电影售票系统项目【项目源码+论文说明】计算机毕业设计

基于java的SSM框架实现电影售票系统演示 摘要 21世纪的今天,随着社会的不断发展与进步,人们对于信息科学化的认识,已由低层次向高层次发展,由原来的感性认识向理性认识提高,管理工作的重要性已逐渐被人们所认识&#…

第1章-第1节-编写第一个Java程序并在命令行编译和运行

第一个Java程序不用任何IDE,用记事本去编写,用命令行去编译并运行,这样便于了解Java程序运行原理。 1、首先打开记事本,写下如下代码: 然后另存为xxx.java,xxx文件名不强求与类名相同,但是建议…

bootstrap:选项卡功能DEMO

<!DOCTYPE html> <html> <head> <meta charset"UTF-8"> <title>选项卡</title> <link rel"stylesheet" type"text/css" href"/cdn.bootcss.com/bootstrap/3.3.2/css/bootstrap.min.css" />…

Python Faker库:轻松生成测试数据

更多Python学习内容&#xff1a;ipengtao.com 大家好&#xff0c;我是彭涛&#xff0c;今天为大家分享 Python Faker库&#xff1a;轻松生成测试数据&#xff0c;全文3300字&#xff0c;阅读大约8分钟。 在开发和测试过程中&#xff0c;经常需要使用虚假数据。Python的Faker库为…

【2023高教社杯】C题 蔬菜类商品的自动定价与补货决策 52页论文及代码

【2023高教社杯】C题 蔬菜类商品的自动定价与补货决策 52页论文及代码 1 题目 C题蔬菜类商品的自动定价与补货决策 在生鲜商超中&#xff0c;一般蔬菜类商品的保鲜期都比较短&#xff0c;且品相随销售时间的增加而变差&#xff0c; 大部分品种如当日未售出&#xff0c;隔日就…

基于Java SSM框架实现高校信息资源共享平台系统【项目源码+论文说明】计算机毕业设计

基于java的SSM框架实现高校信息资源共享平台系统演示 摘要 21世纪的今天&#xff0c;随着社会的不断发展与进步&#xff0c;人们对于信息科学化的认识&#xff0c;已由低层次向高层次发展&#xff0c;由原来的感性认识向理性认识提高&#xff0c;管理工作的重要性已逐渐被人们…

this.$emit(‘update:isVisible‘, false)作用

这个写是不是很新颖&#xff0c;传父组件传值&#xff01;这是什么鬼。。。 假设你有以下逻辑业务。在A页面弹出一个组件B&#xff0c;A组件里面使用B组件&#xff0c;是否展示B组件你使用的是baselineShow变量控制&#xff01; <BaselineData :isVisible.sync"basel…

鸿蒙OS应用开发之数据类型

前面学习了一个简单的例子&#xff0c;这是多年来学习应用程序开发的经典路径&#xff0c;在这里也是这种待遇&#xff0c;通过这样的学习明白了一个简单应用是怎么样构成的&#xff0c;知道它是怎么运行输出的。在这个基础之上&#xff0c;你还是不会开发应用程序的&#xff0…

RabbitMQ学习二

RabbitMQ学习二 发送者的可靠性生产者连接重试机制生产者确认机制开启生产者确认定义ReturnCallback定义confirmCallback MQ的可靠性交换机和队列持久化消息持久化LazyQueue控制台配置Lazy模式代码配置Lazy模式 消费者的可靠性失败重试机制失败处理策略业务幂等性唯一消息ID业务…

在Deepin中安装x11vnc工具并结合内网穿透软件实现远程访问桌面

文章目录 1. 安装x11vnc2. 本地远程连接测试3. Deepin安装Cpolar4. 配置公网远程地址5. 公网远程连接Deepin桌面6. 固定连接公网地址7. 固定公网地址连接测试 x11vnc是一种在Linux系统中实现远程桌面控制的工具&#xff0c;它的原理是通过X Window系统的协议来实现远程桌面的展…

Tair(3):Tair入门demo

新建一个maven项目 1 导入依赖 <dependency><groupId>com.taobao.tair</groupId><artifactId>tair-client</artifactId><version>2.3.5</version></dependency><dependency><groupId>com.alibaba</groupId>…

智能优化算法应用:基于厨师算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于厨师算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于厨师算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.厨师算法4.实验参数设定5.算法结果6.参考文献7.MATLAB…

项目管理工具在电商新品运营中的应用与实践

运营永远是电商的核心命题&#xff0c;新品开发完成后&#xff0c;就进入了新品的运营工作&#xff0c;包括上架前的准备、上架后的推广、商品定位等&#xff0c;且运营一般同时负责多个新品的运营&#xff0c;任务多、时间紧、信息分散&#xff0c;如果缺乏统一管理入口&#…

电脑中环境变量的设置方法

环境变量是在操作系统中一个具有特定名字的对象&#xff0c;它包含了一个或者多个应用程序所将使用到的信息。例如Windows和DOS操作系统中的path环境变量&#xff0c;当要求系统运行一个程序而没有告诉它程序所在的完整路径时&#xff0c;系统除了在当前目录下面寻找此程序外&a…

Mysql- 流程函数-(If, CASE WHEN)的使用及练习

目录 4.1 If函数语法格式 4.2 CASE WHEN 条件表达式格式 4.3 update与 case when 4.4 练习题1 4.5 练习题2 4.6 练习题3-行转列 4.7 牛客练习题 4.8 LeetCode练习题 4.1 If函数语法格式 IF(expr1,expr2,expr3) 解释&#xff1a; 如果表达式expr1true(expr1 <>…

java服务调用mysql报错

一、前言 前端服务调用后端服务时出现以下报错&#xff0c;原因是使用mysql5.7版本数据库中存在ONLY_FULL_GROUP_BY这个配置项导致的不兼容 MySQLSyntaxErrorException: Expression #32 of SELECT list is not in GROUP BY clause and contains nonaggregated column demeter…

系列九、SpringBoot + MyBatis + Redis实现分布式缓存

一、缓存介绍 1.1、概述 缓存是计算机内存中的一段数据&#xff08;PS&#xff1a;内存中的数据具有读写快、断电立即消失的特点&#xff09;&#xff0c;合理地使用缓存能够提高网站的吞吐量和运行效率&#xff0c;减轻数据库的访问压力。那么哪些数据适合缓存呢&#xff1f;…

C++笔记之通过静态类成员变量的方式在不同的类之间传递参数

C笔记之通过静态类成员变量的方式在不同的类之间传递参数 code review! 在C中&#xff0c;可以使用静态类成员变量作为一种在不同类之间传递参数的方式。静态类成员变量是类的所有对象之间共享的变量&#xff0c;它们存在于类的内部&#xff0c;但不属于任何特定的类对象。 …