zoukankan      html  css  js  c++  java
  • LeetCode 24. 两两交换链表中的节点

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

    Difficulty: 中等

    给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。

    你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

    示例 1:

    输入:head = [1,2,3,4]
    输出:[2,1,4,3]
    

    示例 2:

    输入:head = []
    输出:[]
    

    示例 3:

    输入:head = [1]
    输出:[1]
    

    提示:

    • 链表中节点的数目在范围 [0, 100]
    • 0 <= Node.val <= 100

    Solution

    # Definition for singly-linked list.
    # class ListNode:
    #     def __init__(self, val=0, next=None):
    #         self.val = val
    #         self.next = next
    class Solution:
        def swapPairs(self, head: ListNode) -> ListNode:
            if not head: return None
            res = pre = ListNode(-1)
            pre.next = head
            while head and head.next:
                tmp = head.next
                head.next = tmp.next
                tmp.next = head
                pre.next = tmp
                head = head.next
                pre = tmp.next
            return res.next
    
  • 相关阅读:
    Java技术 第六次实验 计科1501 胡开辉
    Java技术 第五次实验 计科1501 胡开辉
    Java第四次作业
    Java第三次作业
    Css新增内容
    Html5新增特性
    Jquery图集
    选项卡
    轮播图
    标准命名
  • 原文地址:https://www.cnblogs.com/swordspoet/p/14163887.html
Copyright © 2011-2022 走看看