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

文章目录

  • 1、题目描述
    • [1.1 移动所有零至数组末尾](#1.1 移动所有零至数组末尾)
    • [1.2 示例](#1.2 示例)
  • 2、解题思路
    • [2.1 思路讲解](#2.1 思路讲解)
    • [2.2 动画演示( 待补充)](#2.2 动画演示( 待补充))
    • [2.3 复杂度分析](#2.3 复杂度分析)
  • 3、答案
    • [3.1 Java 代码](#3.1 Java 代码)
    • [3.2 运行结果](#3.2 运行结果)
  • [4、视频讲解( 待补充)](#4、视频讲解( 待补充))

1、题目描述

1.1 移动所有零至数组末尾

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

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

1.2 示例

示例 1

复制代码
输入: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]

示例 2

复制代码
输入: nums = [0]
输出: [0]

2、解题思路

2.1 思路讲解

  • index变量来记录当前处理到了第几个数字
  • 如果当前数值是 0,进入空循环,不做任何处理
  • 每次处理完一个数字,index +1
  • 末尾补零
  • 注意题目中要求不能拷贝数组

2.2 动画演示( 待补充)

2.3 复杂度分析

  • 时间复杂度 : O ( n ) O(n) O(n)

  • 空间复杂度 : O ( 1 ) O(1) O(1)

3、答案

3.1 Java 代码

java 复制代码
public class _03_移动零 {
 
    public static void main(String[] args) {
        System.out.println(Arrays.toString(moveZeroes(new int[]{0, 1, 0, 3, 12})));
        System.out.println(Arrays.toString(moveZeroes(new int[]{0})));
    }

    private static int[] moveZeroes(int[] nums) {
        int index = 0;   //用来记录当前处理到了第几个数字
        for (int i = 0; i < nums.length; i++) {
            // 如果当前数值是 0,进入空循环,不做任何处理
            if (nums[i] != 0) {
                nums[index] = nums[i];
                index++;    //每次处理完一个数字,index +1
            }
        }
        for (int i = index; i < nums.length; i++) {
            nums[i] = 0;
        }
        return nums;
    }
}

3.2 运行结果

4、视频讲解( 待补充)

相关推荐
郝学胜-神的一滴5 分钟前
干货版《算法导论》04:渐近复杂度与序列接口实战
java·开发语言·数据结构·c++·python·算法
zzzsde5 分钟前
【Linux】信号处理(3)信号处理&&valatile关键字
linux·运维·服务器·开发语言·算法
帅次9 分钟前
Android 高级工程师面试参考答案:项目经历、自我介绍与实战案例表达
android·面试·职场和发展
洛水水18 分钟前
【力扣100题】47.最长递增子序列
算法·leetcode·职场和发展
木子墨51637 分钟前
系统设计面试 | 实现一个限流器:滑动窗口 → 令牌桶 → 漏桶
java·开发语言·数据结构·数据库·面试·职场和发展
环流_1 小时前
Redis zinterstore
算法
不知名的忻1 小时前
交换排序:冒泡排序 vs 快速排序(Java)
java·算法·排序算法
沃普天科技1 小时前
USB显示器多屏异显多屏拼接IF8032 IT690 VL171 8801 RTD2556
arm开发·驱动开发·算法·计算机外设·音视频·硬件工程·pcb工艺
炽烈小老头1 小时前
【 每天学习一点算法 2026/05/14】单词接龙
学习·算法
yxc_inspire1 小时前
24年CCPC山东邀请赛补题
学习·算法