题解 | #链表分割#

链表分割

https://www.nowcoder.com/practice/0e27e0b064de4eacac178676ef9c9d70

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};*/
#include <cstddef>
class Partition {
public:
    ListNode* partition(ListNode* pHead, int x) {
        // write code here
        ListNode* Bighead,*Bigtail;
        ListNode* Lesshead,*Lesstail;
        Lesshead = Lesstail = (ListNode*)malloc(sizeof(ListNode));
        Bighead = Bigtail = (ListNode*)malloc(sizeof(ListNode));
        ListNode* pcur = pHead;
        while(pcur)
        {
            if(pcur->val < x)
            {
                Lesstail->next = pcur;
                Lesstail = Lesstail->next;
            }
            else 
            {
                Bigtail->next = pcur;
                Bigtail = Bigtail->next;
            }
            
            pcur = pcur->next;
        }
        Bigtail->next = NULL;
        Lesstail->next = Bighead->next;
        return Lesshead->next;
    }
};

全部评论

相关推荐

能干的三文鱼刷了10...:公司可能有弄嵌入式需要会画pcb的需求,而且pcb能快速直观看出一个人某方面的实力。看看是否有面试资格。问你问题也能ai出来,pcb这东西能作假概率不高
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务