【LeetCode】【算法】283. 移动零

LeetCode 283. 移动零

题目描述

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

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

思路

简单题,用两个指针解,把所有非0元素置换到数组前面,后面补充0

  1. 定义一个slow指针,专门指向那些0元素,首先用for循环遍历nums数组,找到第一个0位置;
  2. 如果没找到0位置,说明整个数组都不存在0元素,直接返回;
  3. 如果找到了,则fast=slow+1,用for循环使fast遍历完整个nums数组,if (nums[fast]!=0)则将元素赋值给slow,即nums[slow++]=nums[fast],这里之所以是nums[slow++]是因为如果是非0元素,肯定会不断地置换给0位置
  4. 最后从slow出发,将nums后面全部填充为0

代码

java 复制代码
class Solution {
    // 很强的解题思路,直接统计个数,不用做交换,速度上应该会有提升
    public void moveZeroes(int[] nums) {
        int slow = -1;

        // 为slow找到第一个0的位置
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] == 0){
                slow = i;
                break;
            }
        }

        if (slow == -1) // 说明不存在非0元素
            return;

        // 非0元素填充
        int fast = slow + 1;
        for ( ; fast < nums.length; fast++){
            if (nums[fast] != 0){
                nums[slow++] = nums[fast];
            }
        }

        // 0元素填充
        if (slow != 0){
            for ( ; slow < nums.length; slow++){
                nums[slow] = 0;
            }
        }
    }
}
相关推荐
Liangwei Lin15 小时前
LeetCode 287. 寻找重复数
算法·leetcode·职场和发展
OCR_1337162127516 小时前
护照OCR校验位技术解析:从算法逻辑到工程落地,筑牢证件核验安全线
人工智能·算法
Hello.Reader16 小时前
算法基础(十三)——随机算法为什么有时主动引入随机性
java·数据库·算法
likerhood16 小时前
ConcurrentHashMap底层数据结构和面试常见问题
java·数据结构·面试·hashmap
老鱼说AI16 小时前
现代 LangChain 开发指南:从 LCEL 原理到企业级 RAG 与 Agent 实战
java·开发语言·人工智能·深度学习·神经网络·算法·机器学习
小许同学记录成长16 小时前
基于幅度形态与参数聚类的工作模式判别
python·算法·scikit-learn
Languorous.17 小时前
C++数据结构高阶|布隆过滤器(Bloom Filter)深度解析:从原理到手写实现,面试高频考点全覆盖
数据结构·c++·面试
gumichef17 小时前
二叉树_堆
算法
Liangwei Lin17 小时前
LeetCode 70. 爬楼梯
算法
洛水水17 小时前
【力扣100题】38.路径总和 III
算法·leetcode·深度优先