LeetCode刷题记录Java算法提高之LeetCode刷题

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

2019-07-10  本文已影响1人  TheKey_

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

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

示例1:
给定 1->2->3->4, 你应该返回 2->1->4->3.

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/swap-nodes-in-pairs/
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


思路:(使用双指针进行交换)

  1. 我们维护一个头节点 prev, 由头节点创建两个指针 slow = prev.next, fast = prev.next.next
  2. 交换 slow 和 fast 节点的位置
  3. 交换完成之后将 slow 节点指向 prev, 用于交换下一组节点
image.png
public static class ListNode {

        private int val;
        private ListNode next;

        public ListNode(int val) {
            this.val = val;
        }

        //用于测试用例
        public ListNode(int[] arr) {
            if (arr == null || arr.length == 0) throw new NullPointerException("array is Empty");
            this.val = arr[0];
            ListNode cur = this;
            for (int i = 1; i < arr.length; i++) {
                cur.next = new ListNode(arr[i]);
                cur = cur.next;
            }
        }

        @Override
        public String toString() {
            StringBuilder res = new StringBuilder();
            ListNode cur = this;
            while (cur != null) {
                res.append(cur.val + "->");
                cur = cur.next;
            }
            res.append("NULL");
            return res.toString();
        }

    }

   public static ListNode swapPairs(ListNode head) {
        ListNode dummyHead = new ListNode(0);
        dummyHead.next = head;
        ListNode prev = dummyHead;
        while (prev.next != null && prev.next.next != null) {
            ListNode slow = prev.next;
            ListNode fast = prev.next.next;
            slow.next = fast.next;
            prev.next = fast;
            fast.next = slow;
            prev = slow;
        }
        return dummyHead.next;
    }

复杂度分析:

思路:从宏观上考虑

  1. 先考虑递归结束条件:当链表为空或者只有一个元素则不需要进行交换
  2. 我们先创建一个节点next指向head.next,假设next后面的链表是已经排好序的
  3. 那么,我们只需将链表前两位元素调换位置即可
  public static ListNode swapPairs(ListNode head) {
        if (head == null || head.next == null) return head;
        ListNode next = head.next;
        head.next = swapPairs2(next.next);
        next.next = head;
        return next;
    }
    

复杂度分析:

public static void main(String[] args) {
         int[] arr = new int[] {1, 2, 3, 4};
         ListNode listNode = new ListNode(arr);
         System.out.println(listNode);
         System.out.println("两两交换链表中的节点" + swapPairs2(listNode));
    }
1->2->3->4->NULL
两两交换链表中的节点2->1->4->3->NULL

上一篇下一篇

猜你喜欢

热点阅读