[Java·算法·简单] LeetCode 283. 移动零

简介: [Java·算法·简单] LeetCode 283. 移动零

题目

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

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

示例

示例1

输入:nums = [100,4,200,1,3,2]

输出:4

解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4

示例2

输入: nums = [0]

输出: [0]

提示

👉️ 力扣原文

class Solution {
    public void moveZeroes(int[] nums) {
        if(nums == null){
            return;
        }
 
        int j=0;
        for(int i=0;i<nums.length;i++){
            if(nums[i] != 0){
                nums[j++] = nums[i];
            }
        }
 
        for(int i=j;i<nums.length;++i){
            nums[i]=0;
        }
    }
}

详细解读

这段代码实现了将数组中的所有零元素移动到数组末尾的操作,同时保持非零元素的相对顺序不变。下面是对代码的解释:

  1. 首先,检查输入的数组是否为空,如果为空,则直接返回,因为无需进行任何操作。
  2. 创建一个指针j初始化为0,用于记录非零元素应该放置的位置。
  3. 进行一次遍历数组。对于每个非零元素,将其放置到nums[j]位置,并递增j
  4. 完成第一次遍历后,数组中所有的非零元素都已经按顺序移动到了数组的前部,而j的值也指向了下一个可能为零的位置。
  5. 进行第二次遍历,从j开始,将剩余的数组位置都置为零,以完成所有零元素的移动操作。

这段代码的时间复杂度为O(n),其中n是数组的长度,因为它只需要对数组进行两次遍历。

idea上代码运行

public class Main {
    public static void main(String[] args) {
        Solution solution = new Solution();
 
        // 示例用例1
        int[] nums1 = {0, 1, 0, 3, 12};
        solution.moveZeroes(nums1);
        System.out.println("移动零后的数组1:");
        for (int num : nums1) {
            System.out.print(num + " ");
        }
        System.out.println();
 
        // 示例用例2
        int[] nums2 = {0, 0, 0, 1, 2, 3};
        solution.moveZeroes(nums2);
        System.out.println("移动零后的数组2:");
        for (int num : nums2) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
}

相关文章
|
1月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
69 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
1月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
38 0
|
9天前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
1月前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
23 2
|
1月前
|
算法 搜索推荐 Java
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
这篇文章介绍了如何使用Java后端技术,结合Graphics2D和Echarts等工具,生成包含个性化信息和图表的海报,并提供了详细的代码实现和GitHub项目链接。
105 0
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
|
1月前
|
算法 Java 数据中心
探讨面试常见问题雪花算法、时钟回拨问题,java中优雅的实现方式
【10月更文挑战第2天】在大数据量系统中,分布式ID生成是一个关键问题。为了保证在分布式环境下生成的ID唯一、有序且高效,业界提出了多种解决方案,其中雪花算法(Snowflake Algorithm)是一种广泛应用的分布式ID生成算法。本文将详细介绍雪花算法的原理、实现及其处理时钟回拨问题的方法,并提供Java代码示例。
67 2
|
1月前
|
算法 Java Linux
java制作海报一:java使用Graphics2D 在图片上写字,文字换行算法详解
这篇文章介绍了如何在Java中使用Graphics2D在图片上绘制文字,并实现自动换行的功能。
94 0
|
1月前
|
算法 Java
LeetCode(一)Java
LeetCode(一)Java
|
1月前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
19 0
|
3月前
|
算法
测试工程师的技能升级:LeetCode算法挑战与职业成长
这篇文章通过作者亲身体验LeetCode算法题的过程,探讨了测试工程师学习算法的重要性,并强调了算法技能对于测试职业成长的必要性。
68 1
测试工程师的技能升级:LeetCode算法挑战与职业成长