Leetcode 86. Partition List (链表好题)

  1. Partition List
    Medium

Given the head of 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.

Example 1:

Input: head = [1,4,3,2,5,2], x = 3

Output: [1,2,2,4,3,5]

Example 2:

Input: head = [2,1], x = 2

Output: [1,2]

Constraints:

The number of nodes in the list is in the range [0, 200].

-100 <= Node.val <= 100

-200 <= x <= 200

解法1:

注意不能直接用node=node->next。

复制代码
        ListNode *tmp = node->next;
        //node = node->next;
        node->next = NULL;
        node = tmp;

以 [1,4,3,2,5,2] 为例,5后面是2,如果不断开,就会形成环。

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* partition(ListNode* head, int x) {
        ListNode *dummy1 = new ListNode(0), *dummy2 = new ListNode(0);
        ListNode *node1 = dummy1, *node2 = dummy2, *node = head;
        while (node) {
            if (node->val < x) {
                node1->next = node;
                node1 = node1->next;
            } else {
                node2->next = node;
                node2 = node2->next;
            }
            ListNode *tmp = node->next;
            //node = node->next;
            node->next = NULL;
            node = tmp;
        }
        node1->next = dummy2->next;
        ListNode *res = dummy1->next;
        delete(dummy1); delete(dummy2);
        return res;
    }
};
相关推荐
এ᭄画画的北北9 小时前
力扣-51.N皇后
算法·leetcode
1白天的黑夜19 小时前
前缀和-974.和可被k整除的子数组-力扣(LeetCode)
c++·leetcode·前缀和
9 小时前
LeetCode Hot 100 搜索二维矩阵
算法·leetcode·矩阵
小新学习屋9 小时前
《剑指offer》-算法篇-位运算
python·算法·leetcode·职场和发展·数据结构与算法
鼠鼠一定要拿到心仪的offer9 小时前
Day23-二叉树的层序遍历(广度优先搜素)
数据结构·算法·leetcode
YuTaoShao9 小时前
【LeetCode 热题 100】34. 在排序数组中查找元素的第一个和最后一个位置——二分查找
java·数据结构·算法·leetcode
junjunyi9 小时前
【LeetCode 148】算法进阶:排序链表 ( 归并排序、快速排序、计数排序 )
链表·排序·分治·归并
艾莉丝努力练剑10 小时前
【数据结构与算法】数据结构初阶:详解排序(三)——归并排序:递归版本和非递归版本
c语言·开发语言·数据结构·学习·算法·链表·排序算法
Swift社区10 小时前
从字符串中“薅出”最长子串:LeetCode 340 Swift 解法全解析
算法·leetcode·swift
吃着火锅x唱着歌12 小时前
LeetCode 1616.分割两个字符串得到回文串
算法·leetcode·职场和发展