Leetcode热题100 Day3

十六、相交链表

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

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

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

十七、反转链表

朴素。

十八、回文链表

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

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

十九、环形链表

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

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

二十、环形链表II

朴素

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

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

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

二十二、两数相加

遍历即可,比较朴素。

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

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

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

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

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

二十五、随机链表的复制

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

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

二十六、排序链表

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

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

相关推荐
a努力。41 分钟前
国家电网Java面试被问:混沌工程在分布式系统中的应用
java·开发语言·数据库·git·mysql·面试·职场和发展
tobias.b2 小时前
408真题解析-2010-7-数据结构-无向连通图
数据结构·算法·图论·计算机考研·408真题解析
良木生香3 小时前
【鼠鼠优选算法-双指针】003:快乐数 & 004:盛水最多的容器
算法
Cx330❀3 小时前
【优选算法必刷100题】第41-42题(模拟):Z 字形变换,外观数列
c++·算法
沃尔特。3 小时前
直流无刷电机FOC控制算法
c语言·stm32·嵌入式硬件·算法
CW32生态社区3 小时前
CW32L012的PID温度控制——算法基础
单片机·嵌入式硬件·算法·pid·cw32
Cx330❀3 小时前
【优选算法必刷100题】第038题(位运算):消失的两个数字
开发语言·c++·算法·leetcode·面试
漫随流水3 小时前
leetcode回溯算法(93.复原IP地址)
数据结构·算法·leetcode·回溯算法
燃于AC之乐3 小时前
我的算法修炼之路--5——专破“思维陷阱”,那些让你拍案叫绝的非常规秒解
c++·算法·贪心算法·bfs·二分答案·扩展域并查集·动态规划(最长上升子序列)
艾莉丝努力练剑3 小时前
【优选算法必刷100题】第021~22题(二分查找算法):山脉数组的峰顶索引、寻找峰值
数据结构·c++·算法·leetcode·stl