leetcode 2161. 根据给定数字划分数组 中等

给你一个下标从 0 开始的整数数组 nums 和一个整数 pivot 。请你将 nums 重新排列,使得以下条件均成立:

  • 所有小于 pivot 的元素都出现在所有大于 pivot 的元素 之前
  • 所有等于 pivot 的元素都出现在小于和大于 pivot 的元素 中间
  • 小于 pivot 的元素之间和大于 pivot 的元素之间的 相对顺序 不发生改变。
    • 更正式的,考虑每一对 pipjpi 是初始时位置 i 元素的新位置,pj 是初始时位置 j 元素的新位置。如果 i < j 且两个元素 小于(或大于)pivot,那么 pi < pj

请你返回重新排列 nums 数组后的结果数组。

示例 1:

复制代码
输入:nums = [9,12,5,10,14,3,10], pivot = 10
输出:[9,5,3,10,10,12,14]
解释:
元素 9 ,5 和 3 小于 pivot ,所以它们在数组的最左边。
元素 12 和 14 大于 pivot ,所以它们在数组的最右边。
小于 pivot 的元素的相对位置和大于 pivot 的元素的相对位置分别为 [9, 5, 3] 和 [12, 14] ,它们在结果数组中的相对顺序需要保留。

示例 2:

复制代码
输入:nums = [-3,4,3,2], pivot = 2
输出:[-3,2,4,3]
解释:
元素 -3 小于 pivot ,所以在数组的最左边。
元素 4 和 3 大于 pivot ,所以它们在数组的最右边。
小于 pivot 的元素的相对位置和大于 pivot 的元素的相对位置分别为 [-3] 和 [4, 3] ,它们在结果数组中的相对顺序需要保留。

提示:

  • 1 <= nums.length <= 10^5
  • -10^6 <= nums[i] <= 10^6
  • pivot 等于 nums 中的一个元素。

分析:用一个数组记录小于 pivot 的值,一个数组记录大于 pivot 的值,一个变量 cnt 记录等于 pivot 的值,最后按照小于、等于、大于的顺序把这些数拼成一个数组即可。

cpp 复制代码
class Solution {
public:
    vector<int> pivotArray(vector<int>& nums, int pivot) {
        int n=nums.size(),cnt=0;
        vector<int>left,right,ans;
        for(int i=0;i<n;++i)
        {
            if(nums[i]<pivot)left.push_back(nums[i]);
            else if(nums[i]>pivot)right.push_back(nums[i]);
            else cnt++;
        }
        for(int i=0;i<left.size();++i)
            ans.push_back(left[i]);
        for(int i=0;i<cnt;++i)
            ans.push_back(pivot);
        for(int i=0;i<right.size();++i)
            ans.push_back(right[i]);
        return ans;
    }
};
相关推荐
8Qi82 小时前
LeetCode 72:编辑距离(Edit Distance)—— 题解
算法·leetcode·职场和发展·动态规划
8Qi82 小时前
LeetCode 583. 两个字符串的删除操作
算法·leetcode·职场和发展·动态规划
小欣加油4 小时前
Leetcode31 下一个排列
数据结构·c++·算法·leetcode·职场和发展
_日拱一卒5 小时前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
郝学胜-神的一滴5 小时前
力扣 662 :二叉树最大宽度
java·数据结构·c++·python·算法·leetcode·职场和发展
小欣加油5 小时前
leetcode169 多数元素
数据结构·c++·算法·leetcode·职场和发展
如竟没有火炬6 小时前
恢复二叉搜索树
数据结构·数据库·python·leetcode·动态规划
如竟没有火炬6 小时前
整数拆分——动态规划
开发语言·数据结构·python·算法·leetcode·动态规划
sheeta199819 小时前
LeetCode 每日一题笔记 日期:2026.06.06 题目:2196. 根据描述创建二叉树
笔记·算法·leetcode