[双指针] 2. 力扣--复写零

一. 题目描述

二. 解题思路

这种题对下标的掌控极易出错,所以一定要画图,掌握边界情况。

1)首先大思路上我们用的是双指针,一个cur指针遍历数组,另一个dest指针修改数组、复写零。

2)因为要求就地修改,所以一定不能从前往后遍历修改,否则只要出现一个被复写的零就会覆盖下一个值,这很容易看出来。

3)既然不能从前往后,我们可以从后往前。

三. 代码实现

cpp 复制代码
class Solution 
{
public:
    void duplicateZeros(vector<int>& arr) 
    {
        int cur = -1, dest = -1;
        // arr.size()返回size_t类型,与int类型的dest比较时发生类型提升
        // int->size_t,-1->无符号整型的最大值,不会进入第一个循环
        // 所以拿出来隐式类型转换一下
        int n = arr.size()-1; 
        // 1. 遍历找到正常复写结束时,cur和dest的位置
        while(dest < n)
        {
            cur++;
            if(arr[cur] != 0) dest += 1;
            else dest += 2;
        }
        // 如果倒数第二个数是0,dest会到arr.size()的位置
        // 此时如果直接执行arr[dest] = 0;属于越界访问,先处理一下
        if (dest > n)
        {
            dest--;
            arr[dest--] = 0;
            cur--;
        }

        // 从后往前复写
        while(cur >= 0)
        {
            if(arr[cur] != 0) arr[dest--] = arr[cur--];
            else
            {
                arr[dest] = 0;
                arr[dest-1] = 0;
                dest -= 2;
                cur--;
            }
        }
    }
};
相关推荐
阿Y加油吧7 分钟前
从斐波那契到动态规划:两道入门题吃透 DP 核心思想
算法·动态规划·代理模式
米啦啦.8 分钟前
多态性、虚函数
开发语言·c++·算法·多态·抽象类·纯虚函数
承渊政道15 分钟前
【递归、搜索与回溯算法】(二叉树深搜模型拆解与经典题型全面突破)
数据结构·c++·学习·算法·leetcode·macos·bfs
泽020229 分钟前
OJBalancer ----- 基于负载均衡仿leetcode的刷题界面
linux·leetcode·负载均衡
会编程的土豆32 分钟前
常用算法里的细节
数据结构·c++·算法·图论
skilllite作者33 分钟前
为什么我认为 Hermes 需要说明 self-evolution 的设计来源
人工智能·算法·rust·openclaw·agentskills
tankeven38 分钟前
HJ179 小苯的IDE括号问题(easy)
c++·算法
华农DrLai39 分钟前
什么是推荐系统中的负反馈?用户的“踩“和“不感兴趣“怎么用?
人工智能·算法·llm·prompt·知识图谱
木斯佳41 分钟前
前端八股文面经大全:京东零售JDY前端一面(2026-04-14)·面经深度解析
前端·算法·设计模式·ai·断点续传
zore_c41 分钟前
【C++】C++——类的默认成员函数(构造、析构、拷贝构造函数)
java·c语言·c++·笔记·算法·排序算法