⭐算法入门⭐《双指针》简单02 —— LeetCode 283. 移动零

🙉饭不食,水不饮,题必须刷🙉

C语言免费动漫教程,和我一起打卡!
🌞《光天化日学C语言》🌞

LeetCode 太难?先看简单题!
🧡《C语言入门100例》🧡

数据结构难?不存在的!
🌳《画解数据结构》🌳

闭关刷 LeetCode,剑指大厂Offer!
🌌《LeetCode 刷题指引》🌌

LeetCode 太简单?算法学起来!
💜《夜深人静写算法》💜

一、题目

1、题目描述

  给定一个数组 n u m s nums nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
  样例输入: n u m s = [ 0 , − 1 , 0 , 3 , 9 ] nums = [0,-1,0,3,9] nums=[0,1,0,3,9]
  样例输出: [ − 1 , 3 , 9 , 0 , 0 ] [-1,3,9,0,0] [1,3,9,0,0]

2、基础框架

  • c++ 版本给出的基础框架代码如下,要求不采用任何的辅助数组,完成将所有零移动到末尾;
  • 也就是空间复杂度要求 O ( 1 ) O(1) O(1)
class Solution {
public:
    void moveZeroes(vector<int>& nums) {

    }
};

3、原题链接

LeetCode 283. 移动零

二、解题报告

1、思路分析

1)首先,我们定义两个指针 i i i j j j,初始情况下 i = 0 i = 0 i=0 j = 1 j = 1 j=1
2)当 j < n j \lt n j<n 时, 有四种情况需要考虑了:
  a)nums[i]==0, nums[j]==0,这时候, i i i 不能动, j j j 自增,回到 2);
  b)nums[i]==0, nums[j]<>0,这两个元素继续交换,并且 i i i 自增,自增完毕如果和 j j j 相等,则 j j j 自增,回到 2);
  c)nums[i]<>0, nums[j]==0 i i i 自增,自增完毕如果和 j j j 相等,则 j j j 自增,回到 2);
  d)nums[i]<>0, nums[j]<>0 i i i j j j 同时自增,回到 2);

  • 循环的结束条件,一定是 j ≥ n j \ge n jn,这个时候,末尾全是零。

2、时间复杂度

  • 两个指针都只会递增各一次,所以时间复杂度为 O ( n ) O(n) O(n)

3、代码详解

class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        if(nums.size() <= 1) {
            return ;                          // (1)
        }
        int i = 0, j = 1;
        while(j < nums.size()) {
            if(!nums[i] && !nums[j]) {        // (2) 
                ++j;                          
            }else if(!nums[i] && nums[j]) {   // (3)
                int tmp = nums[i];          
                nums[i] = nums[j];
                nums[j] = tmp;
                if(++i == j) ++j;             
            }else if(nums[i] && nums[j]) {    // (4)
                ++i, ++j;
            }else if(nums[i] && !nums[j]) {   // (5)
                if(++i == j) ++j;
            }
        }
    }
};
  • ( 1 ) (1) (1) 当只有一个元素的时候,不需要做任何操作,所以直接返回即可。
  • ( 2 ) (2) (2) 对应 nums[i]==0, nums[j]==0的情况,是否等于零可以用 !来实现;
  • ( 3 ) (3) (3) 对应 nums[i]==0, nums[j]<>0的情况;
  • ( 4 ) (4) (4) 对应 nums[i]<>0, nums[j]<>0的情况;
  • ( 5 ) (5) (5) 对应 nums[i]<>0, nums[j]==0的情况;

三、本题小知识

可以用if(x)来判断表达式x是否为;用if(!x)来判断表达式x是否为


  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

英雄哪里出来

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值