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

LeetCode热题100--283.移动零--简单

1.题目

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
请注意 ,必须在不复制数组的情况下原地对数组进行操作。

示例 1:
输入: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]

示例 2:
输入: nums = [0]
输出: [0]

2.题解

class Solution {public void moveZeroes(int[] nums) {if(nums == null){return;}//两个指针i和jint j = 0;for (int i = 0; i < nums.length; i++){//当前元素!=0,就把其交换到左边,等于0的交换到右边if (nums[i] != 0){int temp = nums[i];nums[i] = nums[j];nums[j++] = temp;}}}
}

3.解析

  1. if(nums == null){ return; } - 如果输入的数字数组为null,则立即返回,因为没有需要处理的内容。
  2. int j = 0; - 初始化一个指针j来跟踪下一个非零元素应该放置的位置。在开始时,它位于第一个位置(索引0)。
  3. for (int i = 0; i < nums.length; i++) {…} - 遍历数组中的每个数字。变量i用于跟踪当前位置的索引,从0到nums.length-1
  4. if(nums[i] != 0){…} - 如果当前元素不等于零(即为非零),则执行以下操作:交换当前元素与下一个非零元素的放置位置。这是通过将它们临时存储在变量temp中来实现的。
  5. int temp = nums[i]; - 将当前非零元素暂时保存在变量temp中。
  6. nums[i] = nums[j]; - 用下一个非零位置(索引j)上的元素替换当前非零位置上的数字。
  7. nums[j++] = temp; - 将原始的非零元素保存在变量temp中,并将其放置在下一个非零元素应该放置的位置上(索引j)。然后递增指针j以准备下一次交换操作。

相关文章:

  • 【开源】STM32HAL库驱动ST7789_240×240(硬件SPI+软件SPI)
  • Postman设置了Cookies但是请求不携带Cookie
  • 2025年04月23日Github流行趋势
  • Sentinel源码—9.限流算法的实现对比一
  • QT项目----电子相册(4)
  • gem5-gpu教程05 内存建模
  • gem5-gpu教程03 当前的gem5-gpu软件架构(因为涉及太多专业名词不知道该如何翻译所以没有汉化)
  • 结构型模式:适配器模式
  • Java 中 String 转 Integer 的方法与底层原理详解
  • Netty是如何实现零拷贝的?
  • leetcode0102. 二叉树的层序遍历-medium
  • Linux安装ffmpeg7.1操作说明
  • Linux之彻底掌握防火墙-----安全管理详解
  • Python项目--基于计算机视觉的手势识别控制系统
  • 学习笔记(C++篇)--- Day 4
  • vue项目打包后点击dist下面index.html(无法访问您的文件该文件可能已被移至别处、修改或删除。ERR_FILE_NOT_FOUND)比如若依
  • Spark论述及其作用
  • 在Notepad++中使用NppAtyle插件格式化代码
  • AI飞行行为的可解释性与合规审计机制设计
  • 6.3.JVM调优与内存管理
  • 先去上海后赴北京,苏中城市泰州为何接连拥抱顶流“大城”?
  • 浙商银行一季度净赚超59亿微增0.61%,非息净收入降逾22%
  • “即买即退”扩容提质,上海静安推出离境退税2.0版新政
  • 习近平在上海考察
  • 俄宣布停火三天,外交部:希望各方继续通过对话谈判解决危机
  • 建发股份:将于5月6日召开股东大会,审议提名林茂等为公司新一届董事等议案