【java学习】【12.10】【10/60】

1.Leetcode(2h)

25. K 个一组翻转链表 - 力扣(LeetCode)

这里注意空值判断;断开链表;局部翻转;链表连接;指针更新

比较全面的hard题

148. 排序链表 - 力扣(LeetCode)

这里用到merge sort进行归并排序,归并排序 是一种分治算法

138. 随机链表的复制 - 力扣(LeetCode)

参考这个视频,用到哈希+递归(这种难理解,注意写成成员变量)或哈希表+遍历

Leetcode 138 复制带随机指针的链表【两种解法:遍历和递归】_哔哩哔哩_bilibili

146. LRU 缓存 - 力扣(LeetCode)

这里注意增加的顺序过程

1.分解2.解决3.合并

2.散列表(哈希表)-散列函数,冲突处理,平均查找长度(0.5h)

散列表(哈希表) - 散列函数, 冲突处理, 平均查找长度(ASL)_哔哩哔哩_bilibili

散列表-实现关键字(key)到下标(地址)

哈希表复杂度O(1),数组的复杂度O(n)

散列函数

直接定址法,除留余数法

冲突处理

不同关键字映射到同一个地址;

开放地址法(线性探测、平方探测):只是标记地址的堆积上有区别
拉链法

在重复的地址上,拉一个链表,然后依次检查链表上的元素,删除就是链表指向后一个即可;

逻辑和专注力得到提升

3.java并发编程(上)(0.15h)

产生死锁的四个必要条件:

  1. 互斥条件:该资源任意一个时刻只由一个线程占用。
  2. 请求与保持条件:一个线程因请求资源而阻塞时,对已获得的资源保持不放。
  3. 不剥夺条件:线程已获得的资源在未使用完之前不能被其他线程强行剥夺,只有自己使用完毕后才释放资源。
  4. 循环等待条件:若干线程之间形成一种头尾相接的循环等待资源关系

4.javaweb复习(1h)

相关推荐
强子感冒了21 小时前
Java网络编程学习笔记,从网络编程三要素到TCP/UDP协议
java·网络·学习
Quintus五等升21 小时前
深度学习④|分类任务—VGG13
人工智能·经验分享·深度学习·神经网络·学习·机器学习·分类
二哈喇子!21 小时前
Java框架精品项目【用于个人学习】
java·spring boot·学习
Mixtral1 天前
2026年4款学习转写工具测评:告别逐字整理,自动生成复习资料
笔记·学习·ai·语音转文字
鄭郑1 天前
【playwright 学习笔记】原理讲解与基础操作 --- day01
笔记·学习
代码游侠1 天前
学习笔记——时钟系统与定时器
arm开发·笔记·单片机·嵌入式硬件·学习·架构
小魏每天都学习1 天前
【计算机基础知识学习】
学习
Nan_Shu_6141 天前
学习: 尚硅谷Java项目之尚庭公寓(2)
学习
好奇龙猫1 天前
【人工智能学习-AI入试相关题目练习-第九次】
人工智能·学习
zhangrelay1 天前
影响移动固态磁盘稳定性的原因有哪些呢?
笔记·学习