千家信息网

Partition相关问题怎么解决

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,本篇内容主要讲解"Partition相关问题怎么解决",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Partition相关问题怎么解决"吧!题意:根据给定链
千家信息网最后更新 2025年01月19日Partition相关问题怎么解决

本篇内容主要讲解"Partition相关问题怎么解决",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Partition相关问题怎么解决"吧!

题意:

根据给定链表和给定值X,把大于X值的放在X右边,小于X值的放在X左边。并不改变相对位置,比如4和3都大于等于3,那么他们移到右边后位置仍为4在前,3在后。

思路:

1)链表为空或者只有一个节点,返回即可。

2)定义两个链表list和back,分别存放小于X节点的链表和大于等于X的链表。使用二级指针方便头节点处理。

3)while循环结束后,list和back链表的最后节点的next并未置NULL。所以把back链表尾节点next置NULL。并把back追加到list后面即可。

/** * Definition for singly-linked list. * struct ListNode { *     int val; *     struct ListNode *next; * }; */struct ListNode* partition(struct ListNode* head, int x){    if ( head == NULL || head->next == NULL )    {        return head;    }    struct ListNode *list = NULL;    struct ListNode **first  = &list;    struct ListNode *back = NULL;    struct ListNode **second = &back;            while ( head )    {           if ( head->val < x)        {               *first = head;            first = &(*first)->next;        }           else        {               *second = head;            second = &(*second)->next;        }                head = head->next;    }        *second = NULL;    *first = back;        return list;}

到此,相信大家对"Partition相关问题怎么解决"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

0