力扣283. 移动零 快慢指针 双指针

解题思路

此处撰写解题思路
数组中元素变化考虑快慢指针
设置初始快慢指针fastdex=0和lowdex=0
遍历数组
fastdex不断后移,直到遇见不等于0的时候,我们可以将快指针的值赋给慢指针
即慢指针从0开始等待快指针遇到第一个不为0的数,然后将这个不为0的数赋给慢指针
赋值之后就可以慢指针后移一位,等待下一个不为0的数
这只是将所有不为0的数去掉
但题目要求我们将0移到后面
所以我们从lowdex开始遍历,将数组后面的值都赋为0

代码

class Solution {
    public void moveZeroes(int[] nums) {
        int n = nums.length;
        int fastdex = 0;
        int lowdex=0;

        for(;fastdex<n;fastdex++){
            if(nums[fastdex] != 0){
                nums[lowdex] = nums[fastdex];
                lowdex++;
            }
        }

        for(;lowdex<n;lowdex++){
            nums[lowdex]=0;
        }

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值