美文网首页LeetCode 之路
LeetCode 86 ——分隔链表

LeetCode 86 ——分隔链表

作者: seniusen | 来源:发表于2018-11-11 17:02 被阅读3次

    1. 题目

    2. 解答

    从前向后遍历链表,将结点值小于 x 的结点放入到新链表 1 中,将结点值大于等于 x 的结点放入新链表 2 中。最后,将新链表 2 拼接在新链表 1 后面即可。

    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     ListNode *next;
     *     ListNode(int x) : val(x), next(NULL) {}
     * };
     */
    class Solution {
    public:
        ListNode* partition(ListNode* head, int x) {
            
            if (head == NULL || head->next == NULL) return head;
            
            ListNode *new_head1 = new ListNode(0); // 新建哨兵结点方便操作
            ListNode *temp1 = new_head1;
            
            ListNode *new_head2 = new ListNode(0); // 新建哨兵结点方便操作
            ListNode *temp2 = new_head2;
            
            while (head)
            {
                if (head->val < x) // 小于 x 的结点放入新链表 1
                {
                    temp1->next = head;
                    temp1 = head;
                }
                else // 大于等于 x 的结点放入新链表 2
                {
                    temp2->next = head;
                    temp2 = head;
                }
                
                head = head->next;
            }
            
            temp1->next = new_head2->next;
            temp2->next = NULL;
            
            return new_head1->next;   
        }
    };
    

    获取更多精彩,请关注「seniusen」!


    相关文章

      网友评论

        本文标题:LeetCode 86 ——分隔链表

        本文链接:https://www.haomeiwen.com/subject/ouzxfqtx.html