zoukankan      html  css  js  c++  java
  • LeetCode-283-移动零

    移动零

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

    示例说明请见LeetCode官网。

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/move-zeroes/
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解法一:数组遍历

    首先,声明一个变量theLastNotZeroPos用来记录最后一个非0的位置,然后从后往前遍历数组nums,如果数组的元素等于0,则需要进行如下处理:

    • 如果当前位置等于theLastNotZeroPos,则将theLastNotZeroPos减一,继续遍历下一个元素;
    • 如果当前位置不等于theLastNotZeroPos,则将当前位置的后一位到theLastNotZeroPos的所有元素全部前移一位,然后想theLastNotZeroPos位置的元素改为0,并且将theLastNotZeroPos减一,然后处理下一个元素。

    遍历完成后,即为移动后的结果。

    public class LeetCode_283 {
        public static void moveZeroes(int[] nums) {
            // 最后一个非0的位置
            int theLastNotZeroPos = nums.length - 1;
            for (int i = nums.length - 1; i >= 0; i--) {
                if (nums[i] == 0) {
                    if (i != theLastNotZeroPos) {
                        for (int j = i; j < theLastNotZeroPos; j++) {
                            nums[j] = nums[j + 1];
                        }
                        nums[theLastNotZeroPos] = 0;
                    }
                    theLastNotZeroPos--;
                }
            }
        }
    
        public static void main(String[] args) {
            int[] nums = new int[]{0, 1, 0, 3, 12};
            System.out.println("-----移动前-----");
            for (int num : nums) {
                System.out.print(num + " ");
            }
            System.out.println();
            moveZeroes(nums);
            System.out.println("-----移动后-----");
            for (int num : nums) {
                System.out.print(num + " ");
            }
        }
    }
    

    【每日寄语】 生活的不确定性,正是我们希望的来源。

  • 相关阅读:
    PTA 天梯赛 L1
    浙江省赛真题2018
    kuangbin专题——简单搜索
    testng.xml 配置大全
    创建testng.xml文件
    TestNG.xml 配置
    Testng 简介
    testng教程之testng.xml的配置和使用,以及参数传递
    jenkins构建:通过testng.xml构建项目
    Jenkins如何集成运行testng.xml文件的解决方案
  • 原文地址:https://www.cnblogs.com/kaesar/p/15270649.html
Copyright © 2011-2022 走看看