算法题 按奇偶排序数组 II

922. 按奇偶排序数组 II

问题描述

给定一个非负整数数组nums,其中一半整数是奇数,另一半是偶数。

你需要对数组进行重排序,使得对于所有偶数索引inums[i]是偶数;对于所有奇数索引inums[i]是奇数。

返回满足条件的任意一种重排序结果。

示例

输入: nums = [4,2,5,7] 输出: [4,5,2,7] 解释: - 索引0(偶数): 4(偶数) - 索引1(奇数): 5(奇数) - 索引2(偶数): 2(偶数) - 索引3(奇数): 7(奇数) 其他有效答案包括: [4,7,2,5], [2,5,4,7], [2,7,4,5]

算法思路

双指针

  1. 使用两个指针:
    • even指针从索引0开始,每次移动2步(只检查偶数位置)
    • odd指针从索引1开始,每次移动2步(只检查奇数位置)
  2. 遍历偶数位置:
    • 如果nums[even]是奇数,说明放错了位置
    • 在奇数位置中找到一个偶数(即nums[odd]是偶数)
    • 交换这两个元素

额外数组

  1. 创建两个列表分别存储偶数和奇数
  2. 按照索引的奇偶性依次从对应列表中取值填充结果数组

代码实现

方法一:双指针原地交换

classSolution{/** * 按奇偶排序数组 II - 双指针原地交换 * * @param nums 输入数组,包含等量的奇数和偶数 * @return 重排序后的数组,偶数索引放偶数,奇数索引放奇数 */publicint[]sortArrayByParityII(int[]nums){intn=nums.length;inteven=0;// 偶数索引指针,从0开始intodd=1;// 奇数索引指针,从1开始// 遍历所有偶数位置while(even<n){// 如果偶数位置放的是奇数if(nums[even]%2==1){// 在奇数位置中找到一个偶数while(nums[odd]%2==1){odd+=2;// 跳到下一个奇数位置}// 交换偶数位置的奇数和奇数位置的偶数swap(nums,even,odd);}even+=2;// 移动到下一个偶数位置}returnnums;}/** * 交换数组中两个位置的元素 */privatevoidswap(int[]nums,inti,intj){inttemp=nums[i];nums[i]=nums[j];nums[j]=temp;}}

方法二:优化双指针

classSolution{/** * 优化:同时移动两个指针 */publicint[]sortArrayByParityII(int[]nums){intn=nums.length;inteven=0;intodd=1;while(even<n&&odd<n){// 找到放错位置的偶数索引(应该是偶数但放了奇数)while(even<n&&nums[even]%2==0){even+=2;}// 找到放错位置的奇数索引(应该是奇数但放了偶数)while(odd<n&&nums[odd]%2==1){odd+=2;}// 如果两个指针都有效,交换它们if(even<n&&odd<n){swap(nums,even,odd);even+=2;odd+=2;}}returnnums;}privatevoidswap(int[]nums,inti,intj){inttemp=nums[i];nums[i]=nums[j];nums[j]=temp;}}

方法三:额外数组

classSolution{/** * 额外数组:使用两个列表分别存储偶数和奇数 */publicint[]sortArrayByParityII(int[]nums){List<Integer>evens=newArrayList<>();List<Integer>odds=newArrayList<>();// 分离偶数和奇数for(intnum:nums){if(num%2==0){evens.add(num);}else{odds.add(num);}}// 按照索引奇偶性重新填充int[]result=newint[nums.length];intevenIndex=0,oddIndex=0;for(inti=0;i<nums.length;i++){if(i%2==0){result[i]=evens.get(evenIndex++);}else{result[i]=odds.get(oddIndex++);}}returnresult;}}

方法四:一次遍历填充

classSolution{/** * 一次遍历填充:直接计算每个元素应该放的位置 */publicint[]sortArrayByParityII(int[]nums){intn=nums.length;int[]result=newint[n];intevenPos=0;// 下一个偶数应该放的位置intoddPos=1;// 下一个奇数应该放的位置for(intnum:nums){if(num%2==0){result[evenPos]=num;evenPos+=2;}else{result[oddPos]=num;oddPos+=2;}}returnresult;}}

算法分析

方法时间复杂度空间复杂度
双指针原地交换O(n)O(1)
优化双指针O(n)O(1)
额外数组O(n)O(n)
一次遍历填充O(n)O(n)

算法过程

输入:nums = [4,2,5,7]

方法一

  1. 初始:even=0,odd=1,nums=[4,2,5,7]
  2. even=0:nums[0]=4(偶数),even=2
  3. even=2:nums[2]=5(奇数)
    • 查找奇数位置的偶数:odd=1,nums[1]=2(偶数)
    • 交换nums[2]nums[1]nums=[4,5,2,7]
    • even=4(超出范围),结束
  4. 返回[4,5,2,7]

输入:nums = [2,3]

  1. even=0:nums[0]=2(偶数),even=2
  2. 结束,返回[2,3]

输入:nums = [3,2]

  1. even=0:nums[0]=3(奇数)
    • odd=1:nums[1]=2(偶数)
    • 交换 →nums=[2,3]
  2. 返回[2,3]

测试用例

publicstaticvoidmain(String[]args){Solutionsolution=newSolution();// 测试用例1:标准示例int[]nums1={4,2,5,7};int[]result1=solution.sortArrayByParityII(nums1.clone());System.out.println("Test 1: "+Arrays.toString(result1));// [4,5,2,7] 或其他有效答案// 测试用例2:已经正确排序int[]nums2={2,1,4,3};int[]result2=solution.sortArrayByParityII(nums2.clone());System.out.println("Test 2: "+Arrays.toString(result2));// [2,1,4,3]// 测试用例3:完全逆序int[]nums3={1,0,3,2};int[]result3=solution.sortArrayByParityII(nums3.clone());System.out.println("Test 3: "+Arrays.toString(result3));// [0,1,2,3] 或其他有效答案// 测试用例4:两元素int[]nums4={2,3};int[]result4=solution.sortArrayByParityII(nums4.clone());System.out.println("Test 4: "+Arrays.toString(result4));// [2,3]int[]nums5={3,2};int[]result5=solution.sortArrayByParityII(nums5.clone());System.out.println("Test 5: "+Arrays.toString(result5));// [2,3]// 测试用例6:大数组int[]nums6={1,2,3,4,5,6,7,8};int[]result6=solution.sortArrayByParityII(nums6.clone());// 验证结果的正确性booleanvalid6=true;for(inti=0;i<result6.length;i++){if(i%2==0&&result6[i]%2!=0)valid6=false;if(i%2==1&&result6[i]%2!=1)valid6=false;}System.out.println("Test 6"+valid6);// true// 测试用例7:全偶数在前int[]nums7={2,4,6,8,1,3,5,7};int[]result7=solution.sortArrayByParityII(nums7.clone());booleanvalid7=true;for(inti=0;i<result7.length;i++){if(i%2==0&&result7[i]%2!=0)valid7=false;if(i%2==1&&result7[i]%2!=1)valid7=false;}System.out.println("Test 7:"+valid7);// true// 测试用例8:包含0int[]nums8={0,1,2,3};int[]result8=solution.sortArrayByParityII(nums8.clone());System.out.println("Test 8: "+Arrays.toString(result8));// [0,1,2,3] 或其他有效答案}

关键点

  1. 双指针

    • 偶数指针只关注偶数位置
    • 奇数指针只关注奇数位置
    • 当发现错位时,必然能在对方的位置找到可交换的元素
  2. 原地操作

    • 空间复杂度为O(1)
    • 不需要额外的存储空间

常见问题

  1. 为什么双指针不会出现死循环?
    • 奇数和偶数数量相等
    • 每次交换都会修复两个错位的位置
    • 最多需要n/2次交换就能完成

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1155611.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机毕业设计springboot博物馆藏品管理系统 基于SpringBoot的文博资产数字化运营平台 SpringBoot驱动的博物馆珍藏智慧管护系统

计算机毕业设计springboot博物馆藏品管理系统 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。当库房里的宋瓷、青铜、书画越积越多&#xff0c;纸质台账却开始“掉链子”&#x…

鸿蒙ArkTS开发实战-从零打造高可用待办事项App【QuickTodo】

鸿蒙ArkTS开发实战&#xff1a;从零打造高可用待办事项App【QuickTodo】 随着鸿蒙生态的迅速发展&#xff0c;越来越多的开发者开始关注鸿蒙设备的应用开发。在这一背景下&#xff0c;ArkTS成为鸿蒙应用开发的首选语言&#xff0c;其声明式UI、强类型校验以及跨设备适配能力&a…

计算机毕业设计springboot博物馆预约管理系统 基于SpringBoot的文博场馆分时预约平台 SpringBoot驱动的智慧博物馆访客预约与票务系统

计算机毕业设计springboot博物馆预约管理系统 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。当“排队两小时&#xff0c;看展十分钟”成为常态&#xff0c;博物馆门口的长龙不仅…

深度调优:在 GNN 涡轮风扇发动机寿命预测中,学习率调度器如何决定模型生死?

前言&#xff1a;为什么学习率是 RUL 预测的“脉搏”&#xff1f; 在处理 NASA C-MAPSS 这样复杂的时间序列空间图结构数据时&#xff0c;我们通常会构建复杂的模型&#xff08;如时空图卷积网络 ST-GCN 或图注意力网络 GAT&#xff09;。然而&#xff0c;即使你有最完美的模型…

大数据领域中 Eureka 的服务注册与发现的容灾备份方案

大数据领域中 Eureka 的服务注册与发现的容灾备份方案关键词&#xff1a;大数据、Eureka、服务注册与发现、容灾备份方案、高可用性摘要&#xff1a;在大数据领域&#xff0c;服务的注册与发现是构建分布式系统的关键环节&#xff0c;Eureka 作为 Netflix 开源的服务注册与发现…

某程旅行小程序爬虫技术解析与实战案例

一、小程序爬虫核心技术认知 1. 小程序与传统 Web 爬虫的核心差异 传统 Web 爬虫主要针对 PC 端或移动端网页&#xff0c;基于 HTML 解析、Cookie 维持、HTTP/HTTPS 请求模拟即可完成大部分数据抓取工作。而小程序爬虫的核心差异体现在三个方面&#xff1a; 传输协议与数据格式…

当代人 “最放不下的前任”

1️⃣ 明明知道吃了胖&#xff0c;却还是忍不住想点那家外卖&#x1f35f;2️⃣ 一直深信能自律&#xff0c;是我做过最自欺欺人的事⏰3️⃣ 嘴上说着要省钱&#xff0c;手却诚实点开购物车&#x1f6d2;4️⃣ 别人问起熬不熬夜&#xff0c;我总说早就早睡&#xff0c;其实在刷…

Python系列Bug修复|如何解决 pip install 安装报错 ModuleNotFoundError: No module named ‘torchaudio’ 问题

摘要 本文聚焦pip install安装torchaudio后&#xff08;或导入torchaudio时&#xff09;出现的ModuleNotFoundError: No module named torchaudio报错&#xff0c;该问题核心是Python解释器在当前运行环境的模块查找路径&#xff08;sys.path&#xff09;中找不到torchaudio模…

算法题 和相同的二元子数组

930. 和相同的二元子数组 问题描述 给你一个二元数组 nums 和一个整数 goal&#xff0c;请你统计并返回有多少个非空连续子数组的和等于 goal。 示例&#xff1a; 输入: nums [1,0,1,0,1], goal 2 输出: 4 解释: 有4个满足要求的子数组: [1,0,1], [1,0,1,0], [0,1,0,1], [1,0…

【毕业设计】基于深度学习卷积神经网络天上飞的识别基于python-CNN深度学习卷积神经网络天上飞的识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

计算机毕业设计springboot财务管理系统 基于SpringBoot的企业财务一体化运营平台 SpringBoot驱动的智能记账与资金管控系统

计算机毕业设计springboot财务管理系统&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。手工做账、Excel满天飞、审批靠签字&#xff0c;月底关账夜夜通宵&#xff1f;把凭证、发票…

AI学习笔记整理(45)——大模型数据读取技术与模型部署

数据读取技术 大模型中的数据读取技术涉及从多样化数据源高效获取和加载数据&#xff0c;是模型训练与推理的基础环节。以下从数据源类型、关键技术方法及工具实践等方面进行说明。 ‌数据源类型与采集方法&#xff1a;‌ 大模型训练数据主要来源于结构化与非结构化数据源。结…

计算机深度学习毕设实战-基于python-CNN机器学习卷积神经网络对蔬菜识别基于python-CNN卷积神经网络对蔬菜识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

江苏硕晟LIMS:全力响应资质认定政策,打造生态环境监测信息管理典范

政策背景与核心要求当下&#xff0c;生态环境监测作为生态治理的核心支撑&#xff0c;其重要性愈发凸显。检验检测机构资质认定生态环境监测机构知识库所提出的各项要求&#xff0c;已成为规范行业发展、保障监测质量的关键准则&#xff0c;其中第十七条更是针对监测机构使用信…

Python系列Bug修复|如何解决 pip install 安装报错 ModuleNotFoundError: No module named ‘torchvision’ 问题

摘要 本文聚焦pip install安装torchvision后&#xff08;或导入torchvision时&#xff09;出现的ModuleNotFoundError: No module named torchvision报错&#xff0c;该问题核心是Python解释器在当前运行环境的模块查找路径&#xff08;sys.path&#xff09;中找不到torchvisi…

企业防泄密软件都有哪些?这六款防泄密软件帮您解决泄密难题!

企业电脑终端藏着半壁江山的核心资产 —— 客户资料、研发方案、商业机密全在这&#xff0c;可员工摸鱼低效、文件随意外传的风险也如影随形。选对监控软件能少走太多弯路&#xff01;2026 实测 6 款高适配工具&#xff0c;既解决员工管理难题&#xff0c;又筑牢数据安全防线&a…

借助AI智能技术,十大专业降重网站提供免费试用服务,帮助用户快速完成文本改写任务

排名 工具名称 降重效率 特色功能 适用场景 免费额度 1 aibiye ⭐⭐⭐⭐⭐ AIGC查重降重双功能 学术论文深度优化 首次免费检测 2 aicheck ⭐⭐⭐⭐ 多维度重复率分析 日常作业/论文初稿 每日3000字免费 3 笔启AI ⭐⭐⭐⭐ 长文记忆多语种支持 硕博论文/…

Python系列Bug修复|如何解决 pip install 安装报错 ModuleNotFoundError: No module named ‘torch’ 问题

摘要 本文聚焦pip install安装torch&#xff08;PyTorch&#xff09;后&#xff08;或导入torch时&#xff09;出现的ModuleNotFoundError: No module named torch报错&#xff0c;该问题核心是Python解释器在当前运行环境的模块查找路径&#xff08;sys.path&#xff09;中找…

Python系列Bug修复|如何解决 pip install 安装报错 ModuleNotFoundError: No module named ‘torch’ 问题

摘要 本文聚焦pip install安装torch&#xff08;PyTorch&#xff09;后&#xff08;或导入torch时&#xff09;出现的ModuleNotFoundError: No module named torch报错&#xff0c;该问题核心是Python解释器在当前运行环境的模块查找路径&#xff08;sys.path&#xff09;中找…

计算机毕业设计springboot材料分析知识系统 基于SpringBoot的材料智能解析与知识共享平台 SpringBoot驱动的材料数据挖掘与性能评估系统

计算机毕业设计springboot材料分析知识系统 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。传统“试-错”研发模式让一种新合金从实验室到产线动辄三五年&#xff0c;背后是海量…