Welcome to Subscribe On Youtube

143. Reorder List

Description

You are given the head of a singly linked-list. The list can be represented as:

L0 → L1 → … → Ln - 1 → Ln

Reorder the list to be on the following form:

L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → …

You may not modify the values in the list's nodes. Only nodes themselves may be changed.

 

Example 1:

Input: head = [1,2,3,4]
Output: [1,4,2,3]

Example 2:

Input: head = [1,2,3,4,5]
Output: [1,5,2,4,3]

 

Constraints:

  • The number of nodes in the list is in the range [1, 5 * 104].
  • 1 <= Node.val <= 1000

Solutions

  • /**
     * 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 void reorderList(ListNode head) {
            ListNode fast = head, slow = head;
            while (fast.next != null && fast.next.next != null) {
                slow = slow.next;
                fast = fast.next.next;
            }
    
            ListNode cur = slow.next;
            slow.next = null;
    
            ListNode pre = null;
            while (cur != null) {
                ListNode t = cur.next;
                cur.next = pre;
                pre = cur;
                cur = t;
            }
            cur = head;
    
            while (pre != null) {
                ListNode t = pre.next;
                pre.next = cur.next;
                cur.next = pre;
                cur = pre.next;
                pre = t;
            }
        }
    }
    
  • /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     ListNode *next;
     *     ListNode() : val(0), next(nullptr) {}
     *     ListNode(int x) : val(x), next(nullptr) {}
     *     ListNode(int x, ListNode *next) : val(x), next(next) {}
     * };
     */
    class Solution {
    public:
        void reorderList(ListNode* head) {
            ListNode* fast = head;
            ListNode* slow = head;
            while (fast->next && fast->next->next) {
                slow = slow->next;
                fast = fast->next->next;
            }
    
            ListNode* cur = slow->next;
            slow->next = nullptr;
    
            ListNode* pre = nullptr;
            while (cur) {
                ListNode* t = cur->next;
                cur->next = pre;
                pre = cur;
                cur = t;
            }
            cur = head;
    
            while (pre) {
                ListNode* t = pre->next;
                pre->next = cur->next;
                cur->next = pre;
                cur = pre->next;
                pre = t;
            }
        }
    };
    
  • # Definition for singly-linked list.
    # class ListNode:
    #     def __init__(self, val=0, next=None):
    #         self.val = val
    #         self.next = next
    class Solution:
        def reorderList(self, head: Optional[ListNode]) -> None:
            fast = slow = head
            while fast.next and fast.next.next:
                slow = slow.next
                fast = fast.next.next
    
            cur = slow.next
            slow.next = None
    
            pre = None
            while cur:
                t = cur.next
                cur.next = pre
                pre, cur = cur, t
            cur = head
    
            while pre:
                t = pre.next
                pre.next = cur.next
                cur.next = pre
                cur, pre = pre.next, t
    
    
  • /**
     * Definition for singly-linked list.
     * type ListNode struct {
     *     Val int
     *     Next *ListNode
     * }
     */
    func reorderList(head *ListNode) {
    	fast, slow := head, head
    	for fast.Next != nil && fast.Next.Next != nil {
    		slow, fast = slow.Next, fast.Next.Next
    	}
    
    	cur := slow.Next
    	slow.Next = nil
    
    	var pre *ListNode
    	for cur != nil {
    		t := cur.Next
    		cur.Next = pre
    		pre, cur = cur, t
    	}
    	cur = head
    
    	for pre != nil {
    		t := pre.Next
    		pre.Next = cur.Next
    		cur.Next = pre
    		cur, pre = pre.Next, t
    	}
    }
    
  • /**
     * Definition for singly-linked list.
     * class ListNode {
     *     val: number
     *     next: ListNode | null
     *     constructor(val?: number, next?: ListNode | null) {
     *         this.val = (val===undefined ? 0 : val)
     *         this.next = (next===undefined ? null : next)
     *     }
     * }
     */
    
    /**
     Do not return anything, modify head in-place instead.
     */
    function reorderList(head: ListNode | null): void {
        let slow = head;
        let fast = head;
    
        while (fast != null && fast.next != null) {
            slow = slow.next;
            fast = fast.next.next;
        }
    
        let next = slow.next;
        slow.next = null;
        while (next != null) {
            [next.next, slow, next] = [slow, next, next.next];
        }
    
        let left = head;
        let right = slow;
        while (right.next != null) {
            const next = left.next;
            left.next = right;
            right = right.next;
            left.next.next = next;
            left = left.next.next;
        }
    }
    
    
  • /**
     * Definition for singly-linked list.
     * function ListNode(val, next) {
     *     this.val = (val===undefined ? 0 : val)
     *     this.next = (next===undefined ? null : next)
     * }
     */
    /**
     * @param {ListNode} head
     * @return {void} Do not return anything, modify head in-place instead.
     */
    var reorderList = function (head) {
        let slow = head;
        let fast = head;
        while (fast.next && fast.next.next) {
            slow = slow.next;
            fast = fast.next.next;
        }
    
        let cur = slow.next;
        slow.next = null;
    
        let pre = null;
        while (cur) {
            const t = cur.next;
            cur.next = pre;
            pre = cur;
            cur = t;
        }
        cur = head;
    
        while (pre) {
            const t = pre.next;
            pre.next = cur.next;
            cur.next = pre;
            cur = pre.next;
            pre = t;
        }
    };
    
    
  • /**
     * Definition for singly-linked list.
     * public class ListNode {
     *     public int val;
     *     public ListNode next;
     *     public ListNode(int val=0, ListNode next=null) {
     *         this.val = val;
     *         this.next = next;
     *     }
     * }
     */
    public class Solution {
        public void ReorderList(ListNode head) {
            ListNode slow = head;
            ListNode fast = head;
            while (fast.next != null && fast.next.next != null) {
                slow = slow.next;
                fast = fast.next.next;
            }
    
            ListNode cur = slow.next;
            slow.next = null;
    
            ListNode pre = null;
            while (cur != null) {
                ListNode t = cur.next;
                cur.next = pre;
                pre = cur;
                cur = t;
            }
            cur = head;
    
            while (pre != null) {
                ListNode t = pre.next;
                pre.next = cur.next;
                cur.next = pre;
                cur = pre.next;
                pre = t;
            }
        }
    }
    
  • // Definition for singly-linked list.
    // #[derive(PartialEq, Eq, Clone, Debug)]
    // pub struct ListNode {
    //   pub val: i32,
    //   pub next: Option<Box<ListNode>>
    // }
    //
    // impl ListNode {
    //   #[inline]
    //   fn new(val: i32) -> Self {
    //     ListNode {
    //       next: None,
    //       val
    //     }
    //   }
    // }
    use std::collections::VecDeque;
    impl Solution {
        pub fn reorder_list(head: &mut Option<Box<ListNode>>) {
            let mut tail = &mut head.as_mut().unwrap().next;
            let mut head = tail.take();
            let mut deque = VecDeque::new();
            while head.is_some() {
                let next = head.as_mut().unwrap().next.take();
                deque.push_back(head);
                head = next;
            }
            let mut flag = false;
            while !deque.is_empty() {
                *tail = if flag { deque.pop_front().unwrap() } else { deque.pop_back().unwrap() };
                tail = &mut tail.as_mut().unwrap().next;
                flag = !flag;
            }
        }
    }
    
    

All Problems

All Solutions