代码随想录算法训练营第四天-链表part2

day2和day3回家太晚,刷完题忘记写笔记了 - -!

24.两两交换链表中的节点

给自己的笔记:

虚拟节点法是创建一个节点,它的next指针指向链表的头节点,这样便于:

  1. current指向虚拟节点,然后对链表进行操作交换
  2. 最后返回头节点:return dummyNode.next
python 复制代码
# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution(object):
    def swapPairs(self, head):
        """
        :type head: ListNode
        :rtype: ListNode
        """
        #创建虚拟节点
        dummyNode=ListNode(next=head)
        #curr 指向dummyNode
        curr=dummyNode
        while(curr.next and curr.next.next):#cur的下一位和下下一位都在 才会进入循环
            temp=curr.next
            temp1=curr.next.next.next
            curr.next=curr.next.next
            curr.next.next=temp
            temp.next=temp1
            curr=curr.next.next#curr往前2位
        return dummyNode.next #返回头节点
       

19 删除链表的倒数第N个节点

  1. 笨办法,先遍历所有节点获得链表长度。
python 复制代码
class Solution(object):
    def removeNthFromEnd(self, head, n):
        """
        :type head: ListNode
        :type n: int
        :rtype: ListNode
        """
        #虚拟头节点
        dummyNode=ListNode(next=head)
        curr=dummyNode
        sizeLink=0
        count=0
        while(curr.next):
            sizeLink+=1
            curr=curr.next
        x=sizeLink-n
        curr=dummyNode
        if(sizeLink==1):
            return None
        if(sizeLink==n):
            return head.next
        while(curr.next):
            curr=curr.next
            count+=1
            if(count==x):
                curr.next=curr.next.next   
        return dummyNode.next
  1. 双指针法
    tips:数组也是可以这样的思路
python 复制代码
class Solution(object):
    def removeNthFromEnd(self, head, n):
        dummyNode=ListNode(next=head)
        slow=dummyNode
        fast=slow
        curr=dummyNode
        for i in range(n+1):#注意是n+1,这样快指针走到尾,慢指针停在要删的节点前一个节点
            fast=fast.next
        
        while(fast!=None):
            fast=fast.next
            slow=slow.next
        slow.next=slow.next.next
        return dummyNode.next

面试题 02.07. 链表相交

核心思想是求两个链表长度差,让指向长链表头指针移动到,和短链表头指针对齐的位置

比如:

A: [4,1,8,4,5]

currA->4

B:[5,0,1,8,4,5]

currB->0

python 复制代码
class Solution(object):
    def getIntersectionNode(self, headA, headB):
        """
        :type head1, head1: ListNode
        :rtype: ListNode
        """
        dummyNodeA=ListNode(next=headA)
        currA=dummyNodeA
        sizeA,sizeB=0,0
        dummyNodeB=ListNode(next=headB)
        currB=dummyNodeB
        curr,curr2=headA,headB
        while curr:
            curr=curr.next
            sizeA+=1
        while curr2:
            curr2=curr2.next
            sizeB+=1
        diff=abs(sizeA-sizeB)#长度差
        
        for i in range(diff):#让长链表指针移动到,和短链表头指针对齐的位置
            if sizeA>sizeB:
                currA=currA.next
            else:
                currB=currB.next
        
        while currA=currB #当指针相等
            currA=currA.next
            currB=currB.next
        return currA
        
        

142.环形链表II

...待补充

相关推荐
Jay200211113 分钟前
【机器学习】23-25 决策树 & 树集成
算法·决策树·机器学习
dragoooon3415 分钟前
[优选算法专题九.链表 ——NO.53~54合并 K 个升序链表、 K 个一组翻转链表]
数据结构·算法·链表
松涛和鸣16 分钟前
22、双向链表作业实现与GDB调试实战
c语言·开发语言·网络·数据结构·链表·排序算法
xlq223226 小时前
22.多态(上)
开发语言·c++·算法
666HZ6666 小时前
C语言——高精度加法
c语言·开发语言·算法
sweet丶6 小时前
iOS MMKV原理整理总结:比UserDefaults快100倍的存储方案是如何炼成的?
算法·架构
云里雾里!7 小时前
力扣 209. 长度最小的子数组:滑动窗口解法完整解析
数据结构·算法·leetcode
CoderYanger8 小时前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:12.全排列
java·算法·leetcode·机器学习·深度优先·剪枝·1024程序员节
憨憨崽&8 小时前
进击大厂:程序员必须修炼的算法“内功”与思维体系
开发语言·数据结构·算法·链表·贪心算法·线性回归·动态规划
chem41119 小时前
C 语言 函数指针和函数指针数组
c语言·数据结构·算法