Leetcode热题100 Day3

十六、相交链表

思路一:可以先遍历两个链表,找到长度差,然后长的先遍历这个差值,再二者同时遍历。

思路二:用哈希集合遍历第一个链表,然后遍历第二个链表,看是否出现在哈希集合。

思路三:遍历第一个,所有遍历过的点做好标记,然后再遍历第二个,看是否遍历到有做标记的点。

十七、反转链表

朴素。

十八、回文链表

思路一:可以先把链表转化为数组,然后两指针遍历。

思路二:可以把链表的后半段逆转,然后和前半段进行比较。

十九、环形链表

思路一:所有遍历过的点存放在哈希表里。这样比较严谨。我的做法是遍历过的节点的值都改编成非常大或非常小的值。

思路二:快慢指针。类似龟兔赛跑,兔子先进入循环,乌龟后进入循环,然后二者总会在循环里相遇。

二十、环形链表II

朴素

二十一、合并两个有序链表

思路一:迭代,此时两个指针分别指向两个链表,不断比较大小。

思路二:递归。这个方法可以减小代码量。

二十二、两数相加

遍历即可,比较朴素。

二十三、删除链表的倒数第N个结点

思路一:先数长度,然后删掉第L-N+1个结点。

思路二:所有结点依次入栈。然后pop n次。取栈顶元素,改变它的指针。

二十四、两两交换链表中的结点

思路不难,但是递归写起来比迭代节省太多时间了!

二十五、随机链表的复制

思路一:哈希表。因为有random,所以第一遍遍历先不管指向关系,只把结点构造出来。然后第二遍遍历利用哈希表得到next和random。

思路二:节点分裂。直接就在旁边拷贝。其实跟哈希表本质思路一样,都是方便找random。

二十六、排序链表

思路一:不考虑空间复杂度的话,直接把链表转成数组,然后对数组进行排序,再构造一个新的链表。

思路二:考虑空间复杂度,需要把数组排序的那一套用在链表中。最适合链表的算法是归并排序,因为直接从中间断开即可。怎么找中点?快慢指针。

相关推荐
GUIQU.35 分钟前
【每日一题 | 2025年5.5 ~ 5.11】搜索相关题
算法·每日一题·坚持
不知名小菜鸡.35 分钟前
记录算法笔记(2025.5.13)二叉树的最大深度
笔记·算法
小雅痞36 分钟前
[Java][Leetcode middle] 55. 跳跃游戏
java·leetcode
真的想上岸啊1 小时前
c语言第一个小游戏:贪吃蛇小游戏05
c语言·算法·链表
元亓亓亓1 小时前
LeetCode热题100--206.反转链表--简单
算法·leetcode·链表
边跑边掩护2 小时前
LeetCode 373 查找和最小的 K 对数字题解
leetcode
诚丞成2 小时前
BFS算法篇——从晨曦到星辰,BFS算法在多源最短路径问题中的诗意航行(上)
java·算法·宽度优先
hongjianMa2 小时前
2024睿抗编程赛国赛-题解
算法·深度优先·图论·caip
czy87874752 小时前
两种常见的C语言实现64位无符号整数乘以64位无符号整数的实现方法
c语言·算法
yzx9910132 小时前
支持向量机案例
算法·机器学习·支持向量机