Leetcode 283-移动零

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

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

题解

题解参考自王尼玛

借鉴快排的思想,将0作为哨兵,从左到右将所有不为零的元素和零元素进行交换

1.left指向第一个为零的元素,right指向left后第一个不为零的元素

2.将nums[left]和nums[right]对换

3.left和right继续移到下一个为零和不为零的位置,直至数组遍历结束

bash 复制代码
class Solution {
    public void moveZeroes(int[] nums) {
        int left=0,right=0;
        while(right<nums.length){
            //left指向第一个为0的元素或者数组长度+1的位置
            while(left<nums.length&&nums[left]!=0) left++;
            right=left+1;
            //right指向第一个为0的元素或者数组长度+1的位置
            while(right<nums.length&&nums[right]==0) right++;
            if(right<nums.length){
                int tmp=nums[left];
                nums[left]=nums[right];
                nums[right]=tmp;
            }
        }
    }
}
相关推荐
YGGP1 天前
【Golang】LeetCode 32. 最长有效括号
算法·leetcode
自然常数e1 天前
字符函数和字符串函数
c语言·算法·visual studio
leaves falling1 天前
c语言分数求和
算法
Das11 天前
【机器学习】01_模型选择与评估
人工智能·算法·机器学习
星轨初途1 天前
郑州轻工业大学2025天梯赛解题
c++·经验分享·笔记·算法·链表·剪枝
不忘不弃1 天前
从字符串中提取数字
数据结构·算法
囊中之锥.1 天前
《机器学习SVM从零到精通:图解最优超平面与软间隔实战》
算法·机器学习·支持向量机
顽强卖力1 天前
第二章:什么是数据分析师?
笔记·python·职场和发展·学习方法
必胜刻1 天前
复原 IP 地址(回溯算法)
tcp/ip·算法·深度优先
YGGP1 天前
【Golang】LeetCode 5. 最长回文子串
算法·leetcode