leetcode-移动零

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

示例 1:

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

输出: [1,3,12,0,0]

示例 2:

输入: nums = [0]

输出: [0]

提示:

1 <= nums.length <= 104

-231 <= nums[i] <= 231 - 1
思路:原数组中执行插入操作移动数据。一个指针start相当于新数组的开始位置,指针i遍历数组。当i指向的当前值不为0时,插入到start的位置,start++。遍历完成后,start之后的数都是0。

c 复制代码
class Solution {
    public void moveZeroes(int[] nums) {
        int start = 0;
        for(int i = 0;i<nums.length;i++){
            if(nums[i]!=0){
                nums[start] = nums[i];
                start++;
            }
        }
        for(int i = start;i<nums.length;i++){
            nums[i] = 0;
        }
    }
}
相关推荐
春栀怡铃声1 分钟前
【C++修仙录02】筑基篇:类和对象(上)
开发语言·c++·算法
自我意识的多元宇宙16 分钟前
二叉树的遍历和线索二叉树--线索二叉树
数据结构
ulias21216 分钟前
leetcode热题 - 3
c++·算法·leetcode·职场和发展
实心儿儿29 分钟前
Linux —— 进程概念 - 程序地址空间
linux·运维·算法
菜鸟丁小真34 分钟前
LeetCode hot100-287.寻找重复数和994.腐烂的橘子
数据结构·算法·leetcode·知识点总结
发发就是发1 小时前
USB系统架构概述:从一次诡异的枚举失败说起
驱动开发·单片机·嵌入式硬件·算法·fpga开发
笨鸟先飞的橘猫1 小时前
数据结构学习——跳表
数据结构·python·学习
少许极端1 小时前
算法奇妙屋(四十七)-ST表
算法·st表·rmq
kishu_iOS&AI1 小时前
Pytorch —— 自动微分模块
人工智能·pytorch·python·深度学习·算法·线性回归
北风toto2 小时前
深入解析JWT Token生成原理与安全加密技术详解
算法·安全·哈希算法