将零移至最后

问题描述 投票:0回答:1

给定一个整数数组 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

public class MoveZeros {
    public void moveZeroes(int[] nums) {

        List<Integer> li = new ArrayList<Integer>(nums.length);
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] != 0) {
                li.add(nums[i]);
            }
        }
        while (nums.length > li.size()) {
            li.add(0);
        }
        for (int i = 0; i < li.size(); i++)
            nums[i] = li.get(i);
    }

    public static void main(String[] args) {
        int num[] = { 0, 1, 0, 3, 12 };
        MoveZeros move = new MoveZeros();
        move.moveZeroes(num);
        System.out.println(Arrays.toString(num));
    }
}

我的解决方案还有其他方法可以解决这个问题吗?

java arrays java-11
1个回答
0
投票

我们可以在不移动零的情况下做到这一点:

import java.util.Arrays;

public class MoveZeros {
    public static void moveZeroes(int[] nums) {
        if (nums == null || nums.length == 0)
            return;

        int pos = 0;
        for (int num : nums)
            if (num != 0)
                nums[pos++] = num;
        while (pos < nums.length)
            nums[pos++] = 0;
    }

    public static void main(String[] args) {
        int num[] = { 0, 1, 0, 3, 12 };
        MoveZeros move = new MoveZeros();
        move.moveZeroes(num);
        System.out.println(Arrays.toString(num));
    }
}

打印

[1, 3, 12, 0, 0]
© www.soinside.com 2019 - 2024. All rights reserved.