十六、相交链表
思路一:可以先遍历两个链表,找到长度差,然后长的先遍历这个差值,再二者同时遍历。
思路二:用哈希集合遍历第一个链表,然后遍历第二个链表,看是否出现在哈希集合。
思路三:遍历第一个,所有遍历过的点做好标记,然后再遍历第二个,看是否遍历到有做标记的点。
十七、反转链表
朴素。
十八、回文链表
思路一:可以先把链表转化为数组,然后两指针遍历。
思路二:可以把链表的后半段逆转,然后和前半段进行比较。
十九、环形链表
思路一:所有遍历过的点存放在哈希表里。这样比较严谨。我的做法是遍历过的节点的值都改编成非常大或非常小的值。
思路二:快慢指针。类似龟兔赛跑,兔子先进入循环,乌龟后进入循环,然后二者总会在循环里相遇。
二十、环形链表II
朴素
二十一、合并两个有序链表
思路一:迭代,此时两个指针分别指向两个链表,不断比较大小。
思路二:递归。这个方法可以减小代码量。
二十二、两数相加
遍历即可,比较朴素。
二十三、删除链表的倒数第N个结点
思路一:先数长度,然后删掉第L-N+1个结点。
思路二:所有结点依次入栈。然后pop n次。取栈顶元素,改变它的指针。
二十四、两两交换链表中的结点
思路不难,但是递归写起来比迭代节省太多时间了!
二十五、随机链表的复制
思路一:哈希表。因为有random,所以第一遍遍历先不管指向关系,只把结点构造出来。然后第二遍遍历利用哈希表得到next和random。
思路二:节点分裂。直接就在旁边拷贝。其实跟哈希表本质思路一样,都是方便找random。
二十六、排序链表
思路一:不考虑空间复杂度的话,直接把链表转成数组,然后对数组进行排序,再构造一个新的链表。
思路二:考虑空间复杂度,需要把数组排序的那一套用在链表中。最适合链表的算法是归并排序,因为直接从中间断开即可。怎么找中点?快慢指针。