leetcodetop100(28) 两两交换链表中的节点

两两交换链表中的节点

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

import Util.ListNode;

//两两交换链表中的节点
//给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。
public class Top28 {
    public static ListNode swapPairs(ListNode head) {
        ListNode dummyHead = new ListNode(0);
        dummyHead.next = head;
        ListNode temp = dummyHead;
        while (temp.next != null && temp.next.next != null) {
            ListNode node1 = temp.next;
            ListNode node2 = temp.next.next;
            temp.next = node2;
            node1.next = node2.next;
            node2.next = node1;
            temp = node1;
        }
        return dummyHead.next;
    }

    public static void main(String[] args) {
        int[] nums = {1,2,3,45,6,7};
        ListNode nodes = ListNode.setNodes(0,nums);
        ListNode.printListData(swapPairs(nodes));
    }
}

harryptter / LeetcodeTop100 · GitCode

你可能感兴趣的:(算法,链表,java,数据结构)