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

目录

057 多路递归 e03 杨辉三角2

057 多路递归 e03 杨辉三角3

058 链表 e01 反转单向链表1

058 链表 e01 反转单向链表2

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

058 链表 e01 反转单向链表4

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

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方法,就是为了拼接这些元素的。 

058 链表 e01 反转单向链表5

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

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

058 链表 e09 判断回文链表2

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【动手学深度学习】(十一)池化层+LeNet

文章目录 一、池化层1.理论知识2.代码 二、LeNet1.理论知识2.代码实现 【相关总结】nn.MaxPool2d() 卷积层对位置比较敏感 一、池化层 1.理论知识 二维最大池化 填充、步幅和多个通道 池化层与卷积层类似,都具有填充和步幅没有可学习的参数在每个输入通道应用池…

【Kubernetes】四层代理Service

Service四层代理 一、Service概念原理1.1、为什么要有Service1.2、Service概述1.3、工作原理1.4、三类IP地址【1】Node Network(节点网络)【2】Pod network(pod 网络)【3】Cluster Network(服务网络) 二、S…

基于Springboot的校园失物招领系统(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的校园失物招领系统(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构…

微信小程序 -- ios 底部小黑条样式问题

问题&#xff1a; 如图&#xff0c;ios有的机型底部伪home键会显示在按钮之上&#xff0c;导致点击按钮的时候误触 解决&#xff1a; App.vue <script>export default {wx.getSystemInfo({success: res > {let bottomHeight res.screenHeight - res.safeArea.bott…

准确!!!在 CentOS 8 上配置 PostgreSQL 14 的主从复制

在 CentOS 8 上配置 PostgreSQL 14 的主从复制&#xff0c;并设置 WAL 归档到特定路径 /home/postgres/archive 的步骤如下&#xff1a; 主服务器配置&#xff08;主机&#xff09; 配置 PostgreSQL&#xff1a; 编辑 postgresql.conf 文件&#xff1a; vim /data/postgres/p…

什么是呼叫中心的语音通道?呼叫中心语音线路有几种?

什么是呼叫中心的语音通道&#xff1f; 呼叫中心的语音通道是指在呼叫中心中使用的语音信号传输通道&#xff0c;它是呼叫中心中至关重要的一部分&#xff0c;负责将客户的语音信息传递给客服代表&#xff0c;以及将客服代表的语音信息传递给客户。在呼叫中心的运营中&#xf…

C语言——字符函数和字符串函数(一)

&#x1f4dd;前言&#xff1a; 这篇文章对我最近学习的有关字符串的函数做一个总结和整理&#xff0c;主要讲解字符函数和字符串函数&#xff08;strlen&#xff0c;strcpy和strncpy&#xff0c;strcat和strncat&#xff09;的使用方法&#xff0c;使用场景和一些注意事项&…

记录 | vscode pyhton c++调试launch.json配置

下面提供 vscode 中 python 和 c 调试配置的 launch.json (好用&#xff0c;已用好几年&#xff0c;建议收藏) {// 使用 IntelliSense 了解相关属性。 // 悬停以查看现有属性的描述。// 欲了解更多信息&#xff0c;请访问: https://go.microsoft.com/fwlink/?linkid830387&qu…

Python开发运维:Python垃圾回收机制

目录 一、理论 1.Python垃圾回收机制 一、理论 1.Python垃圾回收机制 &#xff08;1&#xff09;引⽤计数器 1&#xff09;环状双向链表 refchain 在python程序中创建的任何对象都会放在refchain链表中。 name "david" age 20 hobby ["篮球",游泳…

Ultimate VFX

Ultimate VFX 构建套件:

C.小苯的排列构造

C-小苯的排列构造_北京信息科技大学第十五届程序设计竞赛&#xff08;同步赛&#xff09; (nowcoder.com) 凑2很容易想出来&#xff0c;但是2 4 1 3 这个内核不好想&#xff0c;算是一种尝试和经验吧 #include<bits/stdc.h> using namespace std;int n;int main() {cin&g…

使用RSA工具进行对信息加解密

我们在开发中需要对用户敏感数据进行加解密&#xff0c;比如密码 这边科普一下RSA算法 RSA是非对称加密算法&#xff0c;与对称加密算法不同;在对称加密中&#xff0c;相同的密钥用于加密和解密数据,因此密钥的安全性至关重要;而在RSA非对称加密中&#xff0c;有两个密钥&…

P11 Linux进程编程exec族函数

前言 &#x1f3ac; 个人主页&#xff1a;ChenPi &#x1f43b;推荐专栏1: 《Linux C应用编程&#xff08;概念类&#xff09;_ChenPi的博客-CSDN博客》✨✨✨ &#x1f525; 推荐专栏2: 《C_ChenPi的博客-CSDN博客》✨✨✨ &#x1f6f8;推荐专栏3: ​​​​​​《链表_C…

蓝桥杯物联网竞赛_STM32L071_8_ADC扩展模块

原理图&#xff1a; 扩展模块原理图&#xff1a; RP1和RP2分别对应着AIN1和AIN2&#xff0c;扭动它们&#xff0c;其对应滑动变阻器阻值也会变化 实验板接口原理图&#xff1a; 对应实验板接口PB1和PB0 即AN1对应PB1, AN2对应PB0 CubMx配置&#xff1a; ADC通道IN8和IN9才对…

Python:核心知识点整理大全11-笔记

目录 ​编辑 6.2.4 修改字典中的值 6.2.5 删除键—值对 注意 删除的键—值对永远消失了。 6.2.6 由类似对象组成的字典 6.3 遍历字典 6.3.1 遍历所有的键—值对 6.3.2 遍历字典中的所有键 往期快速传送门&#x1f446;&#xff08;在文章最后&#xff09;&#xff1a; 6.…

Git的安装以及SSH配置

前言 近期工作需要&#xff0c;所以版本管理工具要用到Git&#xff0c;某些操作需要ssh进行操作&#xff0c;在某次操作中遇到&#xff1a;git bash报错&#xff1a;Permission denied, please try again。经排查是ssh没有配置我的key&#xff0c;所以就借着这篇文章整理了一下…

2024年网络安全竞赛-Web安全应用

Web安全应用 (一)拓扑图 任务环境说明: 1.获取PHP的版本号作为Flag值提交;(例如:5.2.14) 2.获取MySQL数据库的版本号作为Flag值提交;(例如:5.0.22) 3.获取系统的内核版本号作为Flag值提交;(例如:2.6.18) 4.获取网站后台管理员admin用户的密码作为Flag值提交…

redis 三主三从高可用集群docker swarm

由于数据量过大&#xff0c;单个Master复制集难以承担&#xff0c;因此需要对多个复制集进行集群&#xff0c;形成水平扩展每个复制集只负责存储整个数据集的一部分&#xff0c;这就是Redis的集群&#xff0c;其作用是提供在多个Redis节点间共享数据的程序集。 官网介绍地址 re…

根据java类名找出当前是哪个Excel中的sheet

pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 …

使用粗糙贴图制作粗纹皮革手提包3D模型

在线工具推荐&#xff1a; 3D数字孪生场景编辑器 - GLTF/GLB材质纹理编辑器 - 3D模型在线转换 - Three.js AI自动纹理开发包 - YOLO 虚幻合成数据生成器 - 三维模型预览图生成器 - 3D模型语义搜索引擎 当谈到游戏角色的3D模型风格时&#xff0c;有几种不同的风格&#xf…