zoukankan      html  css  js  c++  java
  • LeetCode 86 ——分隔链表

    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」!

  • 相关阅读:
    分布式事务-第一刀
    Qt
    自描述C++部分面试题集
    读书笔记6.21
    STL vector容器 和deque容器
    C++ STL框架
    C++ 多态
    C++ 虚继承
    C++ 类的继承和派生
    C++ 类中的函数重载
  • 原文地址:https://www.cnblogs.com/seniusen/p/9958568.html
Copyright © 2011-2022 走看看