【力扣】283. 移动零

题目描述

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

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

示例 1:

输入: nums = [0,1,0,3,12]

输出: [1,3,12,0,0]

示例 2:

输入: nums = [0]

输出: [0]

提示:

  • 1 <= nums.length <= 104
  • -231 <= nums[i] <= 231 - 1

进阶:你能尽量减少完成的操作次数吗?

解题方案

  • C
c 复制代码
void moveZeroes(int* nums, int numsSize) {
    int i = 0, index = 0;
    for(i = 0; i < numsSize; i++)
    {
        if(nums[i] != 0)
        {
            nums[index++] = nums[i];
        }
    }
    for (i = index; i < numsSize; i++) 
    {
        nums[i] = 0;
    }
}
相关推荐
故事和你9112 小时前
洛谷-数据结构1-4-图的基本应用2
开发语言·数据结构·算法·深度优先·动态规划·图论
吴可可12312 小时前
C#合并首尾相连多段线实战
算法·c#
KMDxiaozuanfeng13 小时前
卡梅德生物技术快报|SPR 技术应用|基于 SPR 亲和力的中药活性成分筛选系统实现与数据分析
科技·算法·面试·考试
꧁细听勿语情꧂13 小时前
数据结构概念和算法、时间复杂度、空间复杂度引入
c语言·开发语言·数据结构·算法
Felven14 小时前
B. The 67th 6-7 Integer Problem
数据结构·算法
玉树临风ives14 小时前
atcoder ABC 454 题解
算法·深度优先·图论
钮钴禄·爱因斯晨14 小时前
聚焦操作系统中的PV操作
数据库·算法·系统架构·c#
云泽80814 小时前
笔试算法 - 双指针篇(一):移动零、复写零、快乐数与盛水容器
c++·算法
不才小强14 小时前
目标跟踪算法DeepSort实战
人工智能·算法·目标跟踪
papership14 小时前
【入门级-数学与其他:1.数及其运算:进制与进制转换:二进制、八进制、十进制、十六进制】
算法