优选算法——双指针专题 1.移动零 2.复写零

优选算法------双指针专题 1.移动零 2.复写零

一.移动零

题目传送门(283. 移动零 - 力扣(LeetCode))

1.题目描述

2.算法原理

数组划分 数组分块

什么意思呢?就是把数组按要求划分模块

比如这道题,就是把数组划分成两个模块,前边是非0,后边是0

两个指针dest cur 将数组划分为三部分

两指针作用:

cur:从左向右扫描数组,遍历数组,cur左边就是处理过的,右边就是未处理的

dest:已处理的区间内,最后一个非0的位置

从而可以分为三个区间

当cur到n时,最后一个区间不见了,只剩下前两个区间,并且前边是非0,后边是0

cur指向第一个元素。dest因为还没有确定最后一个非0元素的位置,所以先指向-1

cur移动时会遇见两种情况

1.遇到0时,cur++,从而保证dest+1,cur-1这个区间是0

代码就是cur++

2.遇到非0时,要让这个 值加入到第一个区间,也就是0.dest这个区间,所以要dest移动到下一个位置从而扩大这个区间,并且dest移动到0,再交换此时dest和cur的位置

代码就是

swap(dest+1,cur)

dest++,cur++

3.代码实现

cpp 复制代码
class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        for(int dest=-1,cur=0;cur<nums.size();cur++)
        {
            //cur每轮都++,所以不用单独写cur遇到0的情况
            if(nums[cur])//遇到非0元素时
            swap(nums[++dest],nums[cur]);
        }
    }
};

二.复写零

题目传送门(1089. 复写零 - 力扣(LeetCode))

1.题目描述

2.算法原理

双指针法,先根据"异地"操作,然后优化到"就地"操作

问题难点:直接在原数组上操作会覆盖后续元素

解决方案:分两步操作

第一步:定位最后一个需要复写的元素

使用双指针模拟复写过程:

  • cur:遍历原数组
  • dest:跟踪在新数组中的位置

特殊规则

  • 遇到非零元素:dest移动1位
  • 遇到零元素:dest移动2位(因为零需要被复写)

dest达到或超过数组末尾时,停止遍历,此时的cur就是最后一个需要复写的元素。

第二步:从后向前复写

cur位置开始向前遍历:

  • 遇到非零元素:直接复制到dest位置
  • 遇到零元素:在dest位置写入两个零

边界情况处理

如果最后一个零恰好使dest超出数组边界,需要特殊处理:

  1. 在数组末尾写入一个零
  2. curdest指针相应调整

3.代码实现

cpp 复制代码
class Solution {
public:
    void duplicateZeros(vector<int>& arr) {
        int cur=0,dest=-1,n=arr.size();
        //1.找最后一个数
        while(cur<n)
        {
            if(arr[cur]) dest++;
            else dest+=2;
            if(dest>=n-1) break;
            cur++;
        }
       //2.处理边界情况
        if(dest==n)
        {
            arr[n-1]=0;
            cur--,dest-=2;
        }
        //3.复写
        while(cur>=0)
        {
            if(arr[cur]) arr[dest--]=arr[cur--];
            else{
                arr[dest--]=0;
                arr[dest--]=0;
                cur--;
            }
        }
    }
};
相关推荐
JieE2125 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint4563 天前
C++进阶(1)——前景提要
c++