leetcode-移动零

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

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

示例 1:

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

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

示例 2:

输入: nums = 0

输出: 0

提示:

1 <= nums.length <= 104

-231 <= numsi <= 231 - 1
思路:原数组中执行插入操作移动数据。一个指针start相当于新数组的开始位置,指针i遍历数组。当i指向的当前值不为0时,插入到start的位置,start++。遍历完成后,start之后的数都是0。

c 复制代码
class Solution {
    public void moveZeroes(int[] nums) {
        int start = 0;
        for(int i = 0;i<nums.length;i++){
            if(nums[i]!=0){
                nums[start] = nums[i];
                start++;
            }
        }
        for(int i = start;i<nums.length;i++){
            nums[i] = 0;
        }
    }
}
相关推荐
weixin_4684668544 分钟前
支持向量机新手实战指南
人工智能·python·算法·机器学习·支持向量机
LinHenrY12271 小时前
数据结构(二叉树)
数据结构
炸薯条!1 小时前
树--二叉树--堆
数据结构
weixin_468466852 小时前
机器学习之决策树新手实战指南
人工智能·python·算法·决策树·机器学习·ai
wanghu20242 小时前
ABC460_E题题解
c++·算法
z200509302 小时前
今日算法(回溯子集)
数据结构·算法·leetcode
Hesionberger2 小时前
巧用异或找出唯一数字(多解)
java·数据结构·python·算法·leetcode
变量未定义~2 小时前
阶乘的约数和、斐波那契数列、数列区间最大值(ST表)
数据结构·算法
智者知已应修善业2 小时前
【51单片机象棋快棋赛 电子裁判器】2023-12-27
c++·经验分享·笔记·算法·51单片机
晚风予卿云月2 小时前
二分算法练习
数据结构·c++·算法·竞赛·算法随笔