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、视频讲解( 待补充)

相关推荐
会叫的恐龙2 分钟前
C++ 核心知识点汇总(第四日)(循环结构)
c++·算法·循环结构
sin_hielo7 分钟前
leetcode 3637
数据结构·算法·leetcode
仍然.7 分钟前
算法题目---双指针算法
数据结构·算法·排序算法
2401_841495648 分钟前
【LeetCode刷题】翻转二叉树
python·算法·leetcode··递归·节点·翻转二叉树
嵌入小生00711 分钟前
数据结构与算法 | 完全二叉树的实现、哈希表的实现
linux·c语言·数据结构·算法·vim·嵌入式
渡我白衣14 分钟前
无中生有——无监督学习的原理、算法与结构发现
人工智能·深度学习·神经网络·学习·算法·机器学习·语音识别
小龙报15 分钟前
【数据结构与算法】单链表的综合运用:1.合并两个有序链表 2.分割链表 3.环形链表的约瑟夫问题
c语言·开发语言·数据结构·c++·算法·leetcode·链表
蓝海星梦16 分钟前
GRPO 算法演进:2025 年 RL4LLM 领域 40+ 项改进工作全景解析
论文阅读·人工智能·深度学习·算法·自然语言处理·强化学习
拼好饭和她皆失16 分钟前
图论:最小生成树,二分图详细模板及讲解
c++·算法·图论
傻小胖16 分钟前
19.ETH-挖矿算法-北大肖臻老师客堂笔记
笔记·算法·区块链