当前位置: 首页 > news >正文

LeetCode 2161.根据给定数字划分数组:双指针(O(1)但非源地操作)

【LetMeFly】2161.根据给定数字划分数组:双指针(O(1)但非源地操作)

力扣题目链接:https://leetcode.cn/problems/partition-array-according-to-given-pivot/

给你一个下标从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 <= 105
  • -106<= nums[i] <= 106
  • pivot等于nums中的一个元素。

解题方法:双指针

首先需要明确的是,这道题暂时没有找到合适的原地操作的方法。所谓空间复杂度O ( 1 ) O(1)O(1),实则是因为力扣返回值不计入算法空间复杂度。

开辟一个和原始数组等长的答案数组,使用两个指针分别从左往右存放比p i v o t pivotpivot小的值和从右往左存放比p i v o t pivotpivot大的值。

最后记得把比p i v o t pivotpivot大的部分reverse一下(因为我们是优先把比p i v o t pivotpivot大的值放到最后面了所以需要翻转一下),中间没有填的位置默认赋值为p i v o t pivotpivot

  • 时间复杂度O ( l e n ( n u m s ) ) O(len(nums))O(len(nums))
  • 空间复杂度O ( 1 ) O(1)O(1)

AC代码

C++
/* * @LastEditTime: 2026-06-08 20:34:51 */classSolution{public:vector<int>pivotArray(vector<int>&nums,intpivot){intn=nums.size();vector<int>ans(n,pivot);intl=0,r=n-1;for(inti=0;i<n;i++){if(nums[i]<pivot){ans[l++]=nums[i];}elseif(nums[i]>pivot){ans[r--]=nums[i];}}reverse(ans.begin()+r+1,ans.end());returnans;}};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

http://www.zskr.cn/news/1489856.html

相关文章:

  • 电商物流避坑指南:这8个快递查询痛点,你遇到过几个?
  • 告别截图!MapChart遗传图谱高清导出与个性化样式进阶教程
  • 市面上正规的雾森系统厂家哪家可靠
  • 大模型应用专家,做好随时涨薪的准备吧~
  • STM32F4 CANopen SDO通信调试实录:我是如何用逻辑分析仪抓包解决数据帧错误的
  • 2026乐山油炸串串推荐 脆皮五花肉人气店 - 优质品牌商家
  • 限流:从单机QPS计数器到分布式三层防御体系
  • AD9253 国产替代方向:四通道 14 位 125MSPS ADC 选型注意事项
  • 2026年成都名酒回收商家:核心技术维度深度解析 - 优质品牌商家
  • 过期食品被晒图投诉,舆情处置时发声明为什么被骂更惨
  • 别再傻傻用pip list了!Python包版本查询的5种高效姿势(含Pycharm/VSCode环境)
  • 安卓必备神器,收藏到吃灰都要下!
  • 别再只做本地开发了!手把手教你用IIS和花生壳内网版,把本地项目变成临时演示环境
  • 7不同岗位如何挑选 AI 证书?运营、产品、设计、市场选型全指南
  • 基于深度学习YOLOv10的森林火灾烟雾识别检测系统(YOLOv10+YOLO数据集+UI界面+Python项目源码+模型)
  • 石家庄空调移机怎么选?2026年5家公司全面对比 - 本地品牌推荐
  • 指令周期:一条指令是怎么被执行的?
  • 终极SPT-AKI存档编辑器完全指南:简单快速修改你的单机塔科夫存档 [特殊字符]
  • 技术深度解析:Jasminum - Zotero中文文献管理的架构设计与实现
  • 后 | 室 Backrooms
  • 2026年新能源类本科院校技术办学实力实测与推荐:航空办学特色大学推荐/航空航天类大学推荐/优选推荐 - 优质品牌商家
  • 实战指南 | 企业Geo运营方法论:AI搜索优化实战指南
  • 丰田电动SUV热销,为何此时却放缓电动化步伐?
  • 面向对象设计(OOP)核心思想与 Java 实践总结
  • 河南工科类院校技术维度实测:安阳工学院核心竞争力解析 - 优质品牌商家
  • 掌握Agent技术,抢占高薪先机!小白程序员必备收藏指南
  • OpenClaw 一键部署包|内置全部依赖,开箱即用
  • CAS 为什么效率高?
  • RepoDoc:用知识图谱重构代码文档生成与增量更新
  • 【RT-DETR实战】168、交通监控综合项目:跟踪与计数功能扩展实战手记