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

2022-09-27  本文已影响0人  王侦

题目地址(24. 两两交换链表中的节点)

https://leetcode.cn/problems/swap-nodes-in-pairs/

题目描述

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

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

前置知识

公司

思路

关键点

代码

Java Code:


/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode swapPairs(ListNode head) {
        if (null == head || null == head.next) {
            return head;
        }

        ListNode newHead = head.next;

        // 这里设置了四个指针,比较繁琐
       // prev 前驱,first/second两个要交换的指针,next,后继指针
        ListNode prev = null;
        ListNode first = head;
        ListNode second = head.next;
        ListNode next = second.next;
        while (first != null && second != null) {
            if (prev != null) {
                prev.next = second;
            }
            second.next = first;
            first.next = next;
            prev = first;
            first = next;
            if (first == null) {
                break;
            }
            second = first.next;
            if (null == second) {
                break;
            }
            next = second.next;

        }
        return newHead;
    }
}

使用哑结点的简便写法

class Solution {
    public ListNode swapPairs(ListNode head) {
        if (null == head || null == head.next) {
            return head;
        }

        ListNode dummyHead = new ListNode(0);
        dummyHead.next = head;

        // 这里只需更新两个节点prev 和 first
        ListNode prev = dummyHead;
        ListNode current = head;
        while(current != null && current.next != null) {
            // 另两个节点second和next在循环里面更新即可
            ListNode second = current.next;
            ListNode next = second.next;
            prev.next = second;
            second.next = current;
            current.next = next;

            prev = current;
            current = next;
        }
        return dummyHead.next;
    }
}

Go Code

func swapPairs(head *ListNode) *ListNode {
    if head == nil || head.Next == nil {
        return head
    }
    // 这种直接获取引用的写法,注意初始化时,这里是大括号{}
    dummyHead := &ListNode{0, head}
    prev, first := dummyHead, head
    for first != nil && first.Next != nil {
        second, next := first.Next, first.Next.Next
        prev.Next = second
        second.Next = first
        first.Next = next

        prev = first
        first = next
    }
    return dummyHead.Next
}

复杂度分析

令 n 为数组长度。

上一篇 下一篇

猜你喜欢

热点阅读