Leetcode刷题java之283. 移动零

执行结果:

通过

显示详情

执行用时 :1 ms, 在所有 Java 提交中击败了94.33% 的用户

内存消耗 :41 MB, 在所有 Java 提交中击败了46.20%的用户

题目:

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

示例:

输入: [0,1,0,3,12]
输出: [1,3,12,0,0]

说明:


    必须在原数组上操作,不能拷贝额外的数组。
    尽量减少操作次数。

思路:

使用快慢指针,慢的属于非0的指针,快的属于正常遍历的指针,非零就赋值给慢指针的位置,最后再将后面的数置零。

代码:

class Solution {
    public void moveZeroes(int[] nums) {
        int slow=0;
        int fast=0;
        while(fast=slow;i--)
        {
            nums[i]=0;
        }
    }
}

 

你可能感兴趣的:(java,Leecode,数组,双指针)