码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode_Partition List

时间:2015-04-14 16:48:32      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:c++   algorithm   算法   leetcode   

一.题目

Partition List

  Total Accepted: 34348 Total Submissions: 124815My Submissions

Given a linked list and a value x, partition it such that all nodes less than x come before nodes greater than or equal to x.

You should preserve the original relative order of the nodes in each of the two partitions.

For example,
Given 1->4->3->2->5->2 and x = 3,
return 1->2->2->4->3->5.

Show Tags
Have you met this question in a real interview?  
Yes
 
No

Discuss









二.解题技巧

    这道题是一个普通的链表遍历的题目,需要注意的地方在于必须将链表的最后一个节点的下一个节点更新为null,不然链表会出现环,从而导致死循环的情况。


三.实现代码

/**
* Definition for singly-linked list.
* struct ListNode {
*     int val;
*     ListNode *next;
*     ListNode(int x) : val(x), next(NULL) {}
* };
*/


#include <iostream>

struct ListNode
{
    int val;
    ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};


class Solution
{
public:
    ListNode *partition(ListNode *head, int x)
    {
        ListNode *LessHeader = new ListNode(10);
        ListNode *LessTail = LessHeader;

        ListNode *GreaterHeader = new ListNode(10);
        ListNode *GreaterTail = GreaterHeader;

        while(head != NULL)
        {
            if (head->val < x)
            {
                LessTail->next = head;
                LessTail = head;
            }
            else
            {
                GreaterTail->next = head;
                GreaterTail = head;
            }

            head = head->next;
        }

        LessTail->next = GreaterHeader->next;
        GreaterTail->next = NULL;
        delete GreaterHeader;

        head = LessHeader->next;
        delete LessHeader;

        return head;
    }
};


void Test()
{
    ListNode *head = new ListNode(2);
    head->next = new ListNode(1);
    int x = 2;

    Solution S1;
    ListNode *Result = S1.partition(head, x);

    while (Result != NULL)
    {
        std::cout << "The result is " << Result->val << std::endl;
        Result = Result->next;
    }



}




四.体会

    这只是一道简单的链表遍历题,只不过在生成新的链表的时候,需要注意不要出现环,也就是记得更新最后一个元素的next指针,将其置为null,这也是这道题的一个考点。



版权所有,欢迎转载,转载请注明出处,谢谢技术分享
技术分享




LeetCode_Partition List

标签:c++   algorithm   算法   leetcode   

原文地址:http://blog.csdn.net/sheng_ai/article/details/45042429

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!