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

数据结构与算法之数组: LeetCode 905. 按奇偶排序数组 (Ts版)

按奇偶排序数组

  • https://leetcode.cn/problems/sort-array-by-parity/description/

描述

  • 给你一个整数数组 nums,将 nums 中的的所有偶数元素移动到数组的前面,后跟所有奇数元素。

返回满足此条件的 任一数组 作为答案。

示例 1

输入:nums = [3,1,2,4]
输出:[2,4,3,1]

解释:[4,2,3,1]、[2,4,1,3] 和 [4,2,1,3] 也会被视作正确答案。

示例 2

输入:nums = [0]
输出:[0]

提示

  • 1 <= nums.length <= 5000
  • 0 <= nums[i] <= 5000

Typescript 版算法实现


1 ) 方案1: 两次遍历

function sortArrayByParity(nums: number[]): number[] {const n: number = nums.length;let index: number = 0;const res: number[] = new Array(n).fill(0);// 第一次遍历,将偶数放入结果数组for (const num of nums) {if (num % 2 === 0) {res[index++] = num;}}// 第二次遍历,将奇数放入结果数组for (const num of nums) {if (num % 2 === 1) {res[index++] = num;}}return res;
}

2 ) 方案2: 双指针 + 一次遍历

function sortArrayByParity(nums: number[]): number[] {const n = nums.length;const res = new Array(n).fill(0);let left = 0, right = n - 1;for (const num of nums) {if (num % 2 === 0) {res[left++] = num;} else {res[right--] = num;}}return res;
};

3 ) 方案3: 原地交换

function sortArrayByParity(nums: number[]): number[] {let left = 0, right = nums.length - 1;while (left < right) {while (left < right && nums[left] % 2 === 0) {left++;}while (left < right && nums[right] % 2 === 1) {right--;}if (left < right) {const temp = nums[left];nums[left] = nums[right];nums[right] = temp;left++;right--;}}return nums;
};
http://www.lryc.cn/news/535677.html

相关文章:

  • 【STM32】HAL库Host MSC读写外部U盘及FatFS文件系统的USB Disk模式
  • docker nginx 配置文件详解
  • 如何实现华为云+deepseek?
  • 【学习笔记】计算机网络(三)
  • 稀土抑烟剂——为汽车火灾安全增添防线
  • Qt Pro、Pri、Prf
  • 基于AIOHTTP、Websocket和Vue3一步步实现web部署平台,无延迟控制台输出,接近原生SSH连接
  • 如何在MacOS上查看edge/chrome的扩展源码
  • 【xdoj-离散线上练习H】T234(C++)
  • Docker Desktop Windows 安装
  • springCloud-2021.0.9 之 GateWay 示例
  • JDK8 stream API用法汇总
  • windows生成SSL的PFX格式证书
  • 玩转大语言模型——使用Kiln AI可视化环境进行大语言模型微调数据合成
  • 2025 西湖论剑wp
  • FPGA 28 ,基于 Vivado Verilog 的呼吸灯效果设计与实现( 使用 Vivado Verilog 实现呼吸灯效果 )
  • 单片机简介
  • C++ 设计模式-桥接模式
  • 不小心删除服务[null]后,git bash出现错误
  • 16.React学习笔记.React更新机制
  • 【Elasticsearch】词干提取(Stemming)
  • 【AI论文】10亿参数大语言模型能超越405亿参数大语言模型吗?重新思考测试时计算最优缩放
  • 【设计模式】【行为型模式】状态模式(State)
  • PostgreSQL错误: 编码“UTF8“的字符0x0xe9 0x94 0x99在编码“WIN1252“没有相对应值
  • Mac ARM 架构的命令行(终端)中,删除整行的快捷键是:Ctrl + U
  • Vue2下判断有新消息来时以站内信方式在页面右下角弹出
  • AI语言模型的技术之争:DeepSeek与ChatGPT的架构与训练揭秘
  • 网络安全中的account和audit区别
  • Visual Studio 使用 “Ctrl + /”键设置注释和取消注释
  • 【密评】 | 商用密码应用安全性评估从业人员考核题库(23)