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

目录

058 链表 e10 判环算法1

thinking:什么是空指针?

058 链表 e10 判环算法2

059 数组 e01 合并有序数组1

059 数组 e01 合并有序数组2

060 队列 链表实现1

061 队列 链表实现2

062 队列 环形数组实现 方法1-1

063 队列 环形数组实现 方法1-2

064 队列 环形数组实现 方法2

065 队列 环形数组实现 方法3-1

066 队列 环形数组实现 方法3-2

067 队列 环形数组实现 方法3-3

068 队列 环形数组实现 方法3-4

069 队列 e01 二叉树层序遍历1

069 队列 e01 二叉树层序遍历2


058 链表 e10 判环算法1

重点理解最后的结合部分:兔子充当乌龟,再走a步,就可以来到环入口。而起点到入口又刚好是a步 

thinking:什么是空指针?

解析Java空指针异常:原因、避免和处理-CSDN博客

因此,这里要加上h.next != null ,因为如果h.next 是null,那h.next.next 就相当于对null执行操作,就会出现空指针异常。

058 链表 e10 判环算法2

 

如果环是起点终点都重合的一个闭合大环,就会出现bug,因此,调整一下代码顺序,先判断乌龟和兔子相遇的时候在不在同一位置,如果在同一位置,说明是闭合大环,说明他们此时此刻的位置就是环的入口,直接返回就好,就不要都各再走一步了。

059 数组 e01 合并有序数组1

 

059 数组 e01 合并有序数组2

 

060 队列 链表实现1

061 队列 链表实现2

如果调用了有参构造,就以指定的容量为准;如果没有调用,那就没有限制,因为我们一开始设置了Integer.MAX_VALUE 

 

 做了以上改动

 

062 队列 环形数组实现 方法1-1

判断空:首尾指针指着一个东西

063 队列 环形数组实现 方法1-2

移动指针,意思是控制最后操作的数组范围是什么。 因为不是整一个圆圈都是有效的数组范围。

064 队列 环形数组实现 方法2

原先的判断满还是空的方法,需要留0给尾指针。但是现在判断是满是空就不用了,因为引用了size这个变量。 

065 队列 环形数组实现 方法3-1

 

左边是新方法,右边是旧方法。

左边:tail不是索引,索引是通过tail计算出来的

右边:tail本身是索引,但后面要马上计算下一个索引的位置

 

066 队列 环形数组实现 方法3-2

将Integer转换成Long型,就可以避免head非常大时候,由正数转换成负数,然后出现bug的现象。

067 队列 环形数组实现 方法3-3

理解:移动后的 1101 就是商,那移没的就是余数,也就是111 

 

可以避免head非常大时候,由正数转换成负数,然后出现bug的现象。这样就可以解决取模运算的性能问题以及符号的问题

虽然tail超过了范围,但是它与其他东西的运算结果没有超过范围就可以了。

而且 数组的最大长度也这个值,数组的尾部减去数组的头部是不可能超过数组的最大长度的。

068 队列 环形数组实现 方法3-4

将非2的n次方数转化为2的n次方

如果给的不是2的n次方,就可以采用这样的方法。

方法一

 方法二

 

方法三

069 队列 e01 二叉树层序遍历1

打印出来,再看看有没有孩子,有就放进去【】里面。 

069 队列 e01 二叉树层序遍历2

想要产生空格,出来的效果像一棵树一样的话,就需要控制它什么时候换行,问题转化成,这一层的节点数有多少个,我要循环多少次才要换行。 

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

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

相关文章

MySQL使用窗口函数ROW_NUMBER()、DENSE_RANK()查询每组第一名或每组前几名,窗口函数使用详解

MySQL数据表结构 创建 tbl_class_info 表,表中有四个字段 id、username、score、group_name 使用 ROW_NUMBER()、DENSE_RANK() 查询每组前三名 -- 查询每组前3名 SELECT username, score, group_name FROM ( SELECT username, score, group_name, ROW_NUMBER()…

深入理解JVM虚拟机第二十八篇:详解JVM当中方法重写的本质和虚方法表

😉😉 欢迎加入我们的学习交流群呀: ✅✅1:这是孙哥suns给大家的福利! ✨✨2:我们免费分享Netty、Dubbo、k8s、Mybatis、Spring...应用和源码级别的视频资料 🥭🥭3:QQ群&a…

java--Object

1.Object类的作用 Object类是java中所有类的祖宗类,因此,java中所有类的对象都可以直接使用Object类中提供一些方法 2.Object类的常见方法 ①toString存在的意义:toString()方法存在的意义就是为了被子类重写,以便返回对象具体的…

域渗透之DCSYNC攻击

文章目录 Dcsync详解Dcsync原理权限利用条件利用方式mimikatz后门利用使用Empire下的powerview.ps1脚本执行以上三条ACE Dcsync可逆加密存储密码得MachineAccount口令hash的方法使用DCSync导出所有帐户的hash防御 Dcsync详解 在Dcsync没有出现之前,如果攻击者需要拿…

公交站间的距离

🎈 算法并不一定都是很难的题目,也有很多只是一些代码技巧,多进行一些算法题目的练习,可以帮助我们开阔解题思路,提升我们的逻辑思维能力,也可以将一些算法思维结合到业务代码的编写思考中。简而言之&#…

三翼鸟2023辉煌收官, 定盘2024高质量棋局

最近在不同平台上接连看到这样的热搜话题:用时间胶囊记录2023的自己、2023年度问答、2023十大网络流行语公布… 显然, 2023年进入最后一个月,时间匆匆,这也意味着又到了总结过去和规划未来的时候。拿到结果、取得成绩当然是对202…

12.11作业

1. 完善对话框,点击登录对话框,如果账号和密码匹配,则弹出信息对话框,给出提示”登录成功“,提供一个Ok按钮,用户点击Ok后,关闭登录界面,跳转到其他界面 如果账号和密码不匹配&…

[Linux基础知识]页表

文章目录 1.页表 环境变量2.进程 1.页表 环境变量 一个分页存储管理系统中,地址长度为 32 位,其中页号占 8 位,则页表长度是 页号即页表项的序号,总共占8个二进制位,意味着页表项的个数就是2^8 在CPU和物理内存之间进行…

计算机病毒判定专家系统原理与设计《文字提取人工修正》

内容源于网络。网络上流转的版本实在是不易阅读, 又不忍神作被糟蹋故稍作整理,对于内容仍然有识别不准的地方,网友可留言,我跟进修改。 雷 军 (武汉大学计算机系,430072) 摘要: 本文详细地描述了…

第17章:随堂复习与企业真题(反射机制)

第17章:随堂复习与企业真题(反射机制) 一、随堂复习 1. 反射的概述(熟悉) Java给我们提供了一套API,使用这套API我们可以在运行时动态的获取指定对象所属的类,创建运行时类的对象,…

SpringBoot集成系列--RabbitMQ

文章目录 一、代码1、添加依赖2、配置RabbitMQ连接3、RabbitMQ配置4、创建生产者5、创建消费者6、测试 二、遇到的问题1、Channel shutdown2、收不到信息3、安装RabbitMQ&#xff0c;无法访问控制台访问 一、代码 1、添加依赖 在pom.xml文件中添加RabbitMQ的相关依赖 <de…

排序-选择排序与堆排序

文章目录 一、选择排序二、堆排序三、时间复杂度四、稳定性 一、选择排序 思想&#xff1a; 将数组第一个元素作为min&#xff0c;然后进行遍历与其他元素对比&#xff0c;找到比min小的数就进行交换&#xff0c;直到最后一个元素就停止&#xff0c;然后再将第二个元素min&…