Leetcode热题100 Day3

十六、相交链表

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

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

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

十七、反转链表

朴素。

十八、回文链表

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

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

十九、环形链表

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

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

二十、环形链表II

朴素

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

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

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

二十二、两数相加

遍历即可,比较朴素。

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

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

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

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

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

二十五、随机链表的复制

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

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

二十六、排序链表

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

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

相关推荐
MicroTech20259 分钟前
微算法科技(NASDAQ: MLGO)探索Grover量子搜索算法,利用量子叠加和干涉原理,实现在无序数据库中快速定位目标信息的效果。
数据库·科技·算法
今天背单词了吗98034 分钟前
算法学习笔记:8.Bellman-Ford 算法——从原理到实战,涵盖 LeetCode 与考研 408 例题
java·开发语言·后端·算法·最短路径问题
手握风云-1 小时前
优选算法的链脉之韵:链表专题
数据结构·算法·链表
Coding小公仔1 小时前
LeetCode 151. 反转字符串中的单词
开发语言·c++·算法
稳兽龙1 小时前
P1098 [NOIP 2007 提高组] 字符串的展开
c++·算法·模拟
G.E.N.1 小时前
开源!RAG竞技场(2):标准RAG算法
大数据·人工智能·深度学习·神经网络·算法·llm·rag
写个博客1 小时前
暑假算法日记第三天
算法
✿ ༺ ོIT技术༻1 小时前
剑指offer第2版:动态规划+记忆化搜索
算法·动态规划·记忆化搜索
oioihoii2 小时前
C++11标准库算法:深入理解std::none_of
java·c++·算法
Swift社区2 小时前
Swift 解 LeetCode 320:一行单词有多少种缩写可能?用回溯找全解
开发语言·leetcode·swift