LeetCode初级算法:移动零Move Zeroes

移动零

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

示例:

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

说明:

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

按照题目意思说要尽量精简,所以这里设置一个变量Count来累计为0的数量,在循环中,如果有不为0的数,替换两个位置,将数值为0的往后移动,结果如下:

public void MoveZeroes(int[] nums) {
        int count = 0;
            for(int i = 0; i < nums.Length; i++)
            {
                if(nums[i]== 0)
                {
                    count++;
                }
                else
                {
                    if (count > 0)
                    {
                        nums[i - count] = nums[i];
                        nums[i] = 0;
                    }
                }
            }
    }

 

你可能感兴趣的:(算法,LeetCode,初级算法)