leetcode刷题之283:移动零

问题

实现思路

首先, 将dest指向-1 位置, cur指向下标为0 的位置, 在cur遍历的过程中:

  1. 遇到非零元素则与下标dest+1 位置的元素交换,

  2. 若遇到零元素则只继续cur遍历.

下标为1 的位置上是 非零元素 执行1) 交换得到右图结果 随后cur++ 得到下图结果

下标为2 的位置上是零元素 执行2)

下标为3 的位置上是非零元素 执行1) 交换得到右图结果 随后cur++ 得到下图结果

下标为4 的位置上是非零元素, 执行1) 交换得到右图结果

遍历结束, 实现要求

代码:

java 复制代码
class Solution {
    public void moveZeroes(int[] nums) {
        int cur = 0, dest = -1;
        while(cur < nums.length) {
            if(nums[cur] == 0) {
                cur++;
            } else {
                swap(nums, cur, dest+1);
                cur++;
                dest++;
            }
        }
    }

    public void swap(int[] nums, int left, int right) {
        int tmp = nums[left];
        nums[left] = nums[right];
        nums[right] = tmp;
        return;
    }
}

提交结果:

相关推荐
勤劳的进取家14 小时前
数据链路层基础
网络·学习·算法
Advancer-14 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤14 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
superior tigre15 小时前
78 子集
算法·leetcode·深度优先·回溯
天威?*15 小时前
bitset的数据结构用法
算法·动态规划
hoiii18716 小时前
粒子滤波跟踪系统 - 蒙特卡洛方法实现
算法
weisian15116 小时前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao16 小时前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
ytttr87316 小时前
MATLAB SIFT图像配准实现
算法·机器学习·matlab
小饕16 小时前
从 Word2Vec 到多模态:词嵌入技术的演进全景
人工智能·算法·机器学习