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

相关推荐
小宋加油啊9 小时前
学习机械臂相关知识
学习
十月的皮皮12 小时前
C语言学习笔记20260606- 求月份天数三种写法
c语言·笔记·学习
马士兵教育12 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
lizhihai_9913 小时前
股市学习心得-AI 产业链核心标的梳理清单
大数据·服务器·人工智能·科技·学习
吃好睡好便好14 小时前
说说科学爬山
学习·生活
lunzi_082614 小时前
【学习笔记】《Python编程 从入门到实践》第8章:函数定义、参数传递与模块导入
笔记·python·学习
零陵上将军_xdr15 小时前
后端转全栈学习-Day5-JavaScript 基础-3
开发语言·javascript·学习
05大叔16 小时前
对话系统学习,问答型数据库,闲聊型对话数据库
学习
nashane16 小时前
HarmonyOS 6商城开发学习:抢票倒计时与系统日历提醒——票务类场景的完整落地思路
学习·华为·harmonyos