前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[Java·算法·简单] LeetCode 283. 移动零

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

作者头像
人不走空
发布2024-03-23 09:23:55
590
发布2024-03-23 09:23:55
举报
文章被收录于专栏:学习与分享学习与分享

题目

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

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

示例

示例1
代码语言:javascript
复制
输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。
示例2

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

提示

👉️ 力扣原文

代码语言:javascript
复制
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上代码运行

代码语言:javascript
复制
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();
    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-03-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 示例
    • 示例1
      • 示例2
      • 提示
      • 详细解读
      • idea上代码运行
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档