Leetcode热题100 Day3

十六、相交链表

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

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

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

十七、反转链表

朴素。

十八、回文链表

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

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

十九、环形链表

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

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

二十、环形链表II

朴素

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

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

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

二十二、两数相加

遍历即可,比较朴素。

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

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

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

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

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

二十五、随机链表的复制

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

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

二十六、排序链表

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

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

相关推荐
实心儿儿5 分钟前
算法9:相同的树
算法·leetcode·职场和发展
Zarek枫煜12 分钟前
zig与c3的算法 -- 静态队列
开发语言·stm32·单片机·嵌入式硬件·算法·51单片机
fff98111812 分钟前
基于C++的爬虫框架
开发语言·c++·算法
XiYang-DING15 分钟前
【LeetCode】Easy | 387. 字符串中的第一个唯一字符
算法·leetcode·职场和发展
m0_7434703722 分钟前
C++中的装饰器模式变体
开发语言·c++·算法
1104.北光c°22 分钟前
Leetcode21.合并两个有序链表 双指针+递归 【hot100算法个人笔记】【java写法】
java·后端·程序人生·算法·leetcode·链表·学习方法
花间相见23 分钟前
【JAVA基础14】—— 二维数组详解:从基础到实战应用
java·python·算法
2401_8649592824 分钟前
分布式日志系统实现
开发语言·c++·算法
linhaijiao25 分钟前
C++与人工智能框架
开发语言·c++·算法
Ivanqhz28 分钟前
linearize:控制流图(CFG)转换为线性指令序列
开发语言·c++·后端·算法·rust