【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;
            }
        }
    }
}
相关推荐
繁依Fanyi几秒前
简易安卓句分器实现
java·服务器·开发语言·算法·eclipse
烦躁的大鼻嘎16 分钟前
模拟算法实例讲解:从理论到实践的编程之旅
数据结构·c++·算法·leetcode
C++忠实粉丝33 分钟前
计算机网络socket编程(4)_TCP socket API 详解
网络·数据结构·c++·网络协议·tcp/ip·计算机网络·算法
祁思妙想1 小时前
10.《滑动窗口篇》---②长度最小的子数组(中等)
leetcode·哈希算法
用户37791362947551 小时前
【循环神经网络】只会Python,也能让AI写出周杰伦风格的歌词
人工智能·算法
福大大架构师每日一题1 小时前
文心一言 VS 讯飞星火 VS chatgpt (396)-- 算法导论25.2 1题
算法·文心一言
EterNity_TiMe_1 小时前
【论文复现】(CLIP)文本也能和图像配对
python·学习·算法·性能优化·数据分析·clip
机器学习之心1 小时前
一区北方苍鹰算法优化+创新改进Transformer!NGO-Transformer-LSTM多变量回归预测
算法·lstm·transformer·北方苍鹰算法优化·多变量回归预测·ngo-transformer
yyt_cdeyyds2 小时前
FIFO和LRU算法实现操作系统中主存管理
算法
daiyang123...2 小时前
测试岗位应该学什么
数据结构