【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)

相关推荐
通信小呆呆14 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick14 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee14 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn8614 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e14 天前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
小雨下雨的雨14 天前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙
cqbzcsq14 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
YangYang9YangYan14 天前
2026初入职场学习数据分析的价值
学习·数据挖掘·数据分析
guslegend14 天前
理论学习:什么是 Coding Agent?
学习
自传.14 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding