zoukankan      html  css  js  c++  java
  • [leetcode] 283. Move Zeroes 解题报告

    Given an array nums, write a function to move all 0's to the end of it while maintaining the relative order of the non-zero elements.

    For example, given nums = [0, 1, 0, 3, 12], after calling your function, nums should be [1, 3, 12, 0, 0].

    Note:

    1. You must do this in-place without making a copy of the array.
    2. Minimize the total number of operations.

    从后往前遍历,为0的数和后面所有的数交换,复杂度为n2

    一刷:

        public void moveZeroes(int[] nums) {
            int zeros=0;
            for (int i = nums.length - 1; i >= 0; i--) {
                if (nums[i] == 0){
                    for (int j = i; j < nums.length - 1 ; j++) {
                        nums[j] = nums[j+1];
                    }
                    nums[nums.length-zeros-1] = 0;
                    zeros += 1;
                }
            }
        }
  • 相关阅读:
    64_l2
    64_l1
    64_k2
    64_k1
    64_j2
    64_j1
    64_g6
    64_g5
    64_g4
    64_g3
  • 原文地址:https://www.cnblogs.com/pulusite/p/5840687.html
Copyright © 2011-2022 走看看