12.9_黑马数据结构与算法笔记Java
目录
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要回去旧队伍了。
相关文章:

12.9_黑马数据结构与算法笔记Java
目录 057 多路递归 e03 杨辉三角2 thinking:二维数组的动态初始化? 057 多路递归 e03 杨辉三角3 058 链表 e01 反转单向链表1 058 链表 e01 反转单向链表2 058 链表 e01 反转单向链表3 递归 058 链表 e01 反转单向链表4 为什么是returnn1呢&…...
K8S学习指南(1)-docker的安装
文章目录 引言1. Windows 系统中安装 Dockera. 确认系统要求b. 下载 Docker Desktopc. 安装 Docker Desktopd. 配置 Docker Desktope. 验证安装 2. Ubuntu 系统中安装 Dockera. 更新包列表b. 安装依赖包c. 添加 Docker GPG 密钥d. 添加 Docker APT 仓库e. 安装 Dockerf. 添加用…...

vue3 + mark.js 实现文字标注功能
效果图 安装依赖 npm install mark.js --save-dev npm i nanoid代码块 <template><!-- 文档标注 --><header><el-buttontype"primary":disabled"selectedTextList.length 0 ? true : false"ghostclick"handleAllDelete"…...

运筹优化 | 模拟退火求解旅行商问题 | Python实现
"""模拟退火旅行商""" import random import numpy as np import math import time import matplotlib.pyplot as plt plt.rcParams[font.sans-serif] [SimHei] plt.rcParams[axes.unicode_minus] False location np.loadtxt(city_location.t…...
1017 A除以B
本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 ABQR 成立。 输入格式: 输入在一行中依次给出 A 和 B,中间以 1 空格分隔。 输出格式: 在一行中依…...
SAP UI5 walkthrough step8 Translatable Texts
在这个章节,我们会将一些文本常量独立出一个资源文件 这样的话,可以方便这些文本常量被翻译成任意的语言 这种国际化的操作,我们一般命名为i18n 新建一个文件i18n.properties webapp/i18n/i18n.properties (New) showHelloButtonTextSay …...

RocketMQ-源码架构二
梳理一些比较完整,比较复杂的业务线 消息持久化设计 RocketMQ的持久化文件结构 消息持久化也就是将内存中的消息写入到本地磁盘的过程。而磁盘IO操作通常是一个很耗性能,很慢的操作,所以,对消息持久化机制的设计,是…...

Unity_ET框架项目-斗地主_启动运行流程
unity_ET框架项目-斗地主_启动运行流程 项目源码地址: Viagi/LandlordsCore: ET斗地主Demohttps://github.com/Viagi/LandlordsCore下载项目到本地。 启动运行步骤: 下载目录如下: 1. VS(我用是2022版VisualStudio)…...

自动化测试框架 —— pytest框架入门篇
今天就给大家说一说pytest框架。 今天这篇文章呢,会从以下几个方面来介绍: 01、pytest框架介绍 pytest 是 python 的第三方单元测试框架,比自带 unittest 更简洁和高效,支持非常丰富的插件,同时兼容 unittest 框架。…...
String类详解
String类详解 大家好,我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿! 解密String类:探秘Java中的字符串魔法 在Java的世界里,String类犹如一位魔法…...

Linux高级管理--安装MySQL数据库系统
MySQL服务基础 MySQL.是一个真正的多线程、多用户的SQL数据库服务,凭借其高性能、高可靠和易于使 用的特性,成为服务器领域中最受欢迎的开源数据库系统。在2008年以前,MySOL项目由MySQL AB公司进行开发,发布和支持,之后…...

团建策划信息展示服务预约小程序效果如何
团建是中大型企业商家每年举办的员工活动,其形式多样化、具备全部参与的娱乐性。但在实际策划流程及内容时,部分公司便会难以入手,术业有专攻,这个时候团建策划公司便会发挥效果。 如拓展训练、露营、运动会、体育竞技等往往更具…...

一个Redis实例最多能存放多少keys
程序员的公众号:源1024,获取更多资料,无加密无套路! 最近整理了一份大厂面试资料《史上最全大厂面试题》,Springboot、微服务、算法、数据结构、Zookeeper、Mybatis、Dubbo、linux、Kafka、Elasticsearch、数据库等等 …...

K8S(四)—pod详解
目录 pod介绍Pod的概念:Pod的特性:Pod的配置:Pod的控制:示例 YAML 文件: pod启动流程问题 两种方式启动镜像的升级和回滚更新 Deployment:回滚检查 Deployment 历史版本回滚到之前的修订版本缩放 Deploymen…...

shiro Filter加载和执行 源码解析
一、背景 在使用若依框架(前后端不分离包含shiro安全框架)时,发现作者添加了验证码、登录帐号控制等自定义过滤器,于是对自定的过滤器加载和执行流程产生疑问。下面以验证码过滤器为例,对源码解析。注意类之间的继承关…...
IDEA上传jar包到Maven
mvn install:install-file //固定格式,maven的语法 -Dfilealibaba-sdk-1.0.0.jar //这里填写包的路径,因为我们是在当前目录所以只需要输入包名即可 -DgroupIdcom.qiehua.csdn //这里填写包的groupId,之后作为pom.xml中引用的gr…...

JavaScript——基本语法
1.定义变量: 变量类型 变量名 变量值 var关键字声明变量 es6版本以上 var 可写可不写 <script>// 定义变量:变量类型 变量名 变量值 var关键字声明变量 es6版本以上 var 可写可不写var num 2;</script>2.条件控制 <script>var …...

一款最近很火的开源低代码平台
低代码平台近年来获得大量融资的原因是多方面的。首先,低代码平台代表了软件开发领域的一个重要趋势,即通过简化编程过程来降低技术门槛,使非专业开发者也能构建应用程序。这为那些希望加速数字化转型的企业提供了新的可能性,因此…...
vue之代理配置devServer(vue.config.js)片段
关于vue.config.js的部分配置解析:首先看下面一段配置 devServer: { open: process.platform darwin,//true or false (true则启动项目自动打开系统自带浏览器) host: 0.0.0.0, // 配置devServer服务监听的地址 比如:想让局域网…...

CTD测试流程
连接 连接17Plus,用usb转232线,db9公针2、3分别接Data I/O的2、3。DB9的5接Data I/O的1。尼龙塞子打开状态。不用闭合。 软件连接 打开SeaTermAF V2,注意打开前先把串口插上,否则软件读不到串口。如果读不到,就在插…...
挑战杯推荐项目
“人工智能”创意赛 - 智能艺术创作助手:借助大模型技术,开发能根据用户输入的主题、风格等要求,生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用,帮助艺术家和创意爱好者激发创意、提高创作效率。 - 个性化梦境…...

深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录
ASP.NET Core 是一个跨平台的开源框架,用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录,以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...

【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...
【python异步多线程】异步多线程爬虫代码示例
claude生成的python多线程、异步代码示例,模拟20个网页的爬取,每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程:允许程序同时执行多个任务,提高IO密集型任务(如网络请求)的效率…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)
Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败,具体原因是客户端发送了密码认证请求,但Redis服务器未设置密码 1.为Redis设置密码(匹配客户端配置) 步骤: 1).修…...
2023赣州旅游投资集团
单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

Mysql中select查询语句的执行过程
目录 1、介绍 1.1、组件介绍 1.2、Sql执行顺序 2、执行流程 2.1. 连接与认证 2.2. 查询缓存 2.3. 语法解析(Parser) 2.4、执行sql 1. 预处理(Preprocessor) 2. 查询优化器(Optimizer) 3. 执行器…...

GitFlow 工作模式(详解)
今天再学项目的过程中遇到使用gitflow模式管理代码,因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存,无论是github还是gittee,都是一种基于git去保存代码的形式,这样保存代码…...

PHP 8.5 即将发布:管道操作符、强力调试
前不久,PHP宣布了即将在 2025 年 11 月 20 日 正式发布的 PHP 8.5!作为 PHP 语言的又一次重要迭代,PHP 8.5 承诺带来一系列旨在提升代码可读性、健壮性以及开发者效率的改进。而更令人兴奋的是,借助强大的本地开发环境 ServBay&am…...