当前位置: 首页 > 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调优与内存管理
  • 习近平在气候和公正转型领导人峰会上的致辞(全文)
  • 最高法典型案例:学生在校受伤,学校并非必然担责
  • 兰斯莫斯想在雅典卫城拍《拯救地球》,希腊当局:价值观不符
  • 龚正会见巴西里约热内卢州州长克劳迪奥·卡斯特罗
  • 金发科技去年净利增160%,机器人等新领域催生材料新需求
  • 国家疾控局局长沈洪兵:将逐步缩小国内免疫规划与国际差距