leetCode 283.移动零

题目

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
请注意 ,必须在不复制数组的情况下原地对数组进行操作。

示例 1:
输入: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]

示例 2:
输入: nums = [0]
输出: [0]

思路:

双指针。
如果数组没有0,那么快慢指针始终指向同一个位置,每个位置自己和自己交换;
由于数组有0,快指针先走一步,此时慢指针对应的就是0,所以要交换。交换后0就都在右边了。

代码:

class Solution {
    public void moveZeroes(int[] nums) {
        if (nums==null) {
            return ;
        }
        //左右指针
        int left = 0;
        int right = 0;
        int length = nums.length;

        while ( right< length) {
            if (nums[right] != 0) {
                //如果数组没有0,那么快慢指针始终指向同一个位置,每个位置自己和自己交换;
                //由于数组有0,快指针先走一步,此时慢指针对应的就是0,所以要交换。交换后0就都在右边了。
                swap( nums, left, right);
                left++;
            }
            right++;

        }
    }


    /**
     *   交换
     */
    public void swap(int[] nums, int left, int right) {
        int temp = nums[left];
        nums[left] = nums[right];
        nums[right] = temp;

    }
}

posted on 2025-01-04 13:08  乐之者v  阅读(19)  评论(0)    收藏  举报

导航