优先算法 —— 双指针系列 - 复写零

目录

[1. 复写零](#1. 复写零)

[2. 算法原理](#2. 算法原理)

一般情况下

改为就地操作:从左到右(错误)

从右到左

总结一下解决方法:

如何找到最后一个复写的数

特殊情况

完整步骤:

[3. 代码](#3. 代码)


1. 复写零

题目链接:
1089. 复写零 - 力扣(LeetCode)https://leetcode.cn/problems/duplicate-zeros/description/


2. 算法原理

其实本题严格来说是一题半模拟半双指针的题目

一般情况下

我们可以先进行异地操作,然后再优化成为双指针下的就地操作

当Cur遇到非0元素的时候,直接写下来,当遇到0的时候,就需要写两遍.....

改为就地操作:从左到右(错误)

将两个指针定义到一个数组上

但是我们发现:当cur到达第一个0时,dest执行两次写入0,将原本2的值给覆盖掉了,那么整个数组都会出现错误,所以从左到右这个方法是不可以的

从右到左

那我们来试试从右到左能否成功

因为是从右到左,所以我们将dest指向最后一个数,cur指向最后一个复写的数,以示例1为例,就是指向4

如果cur当前指向的值不为0,那么就直接把cur指向的值写入dest,再同时--

如果cur当前指向的值为0,那么cur往左移动一位,dest移动2位

然后我们发现从右到左这种方法是可以的

总结一下解决方法:

1. 先找到最后一个复写的数

2. 以从右到左的顺序完成复写操作

如何找到最后一个复写的数

双指针算法

1. 定义一个cur指向数组里第一个数的位置,dest指向-1的位置

因为要把dest定义为结果中最后一个的位置,因此我们只需要判断dest是否跑到最后一个位置就可以了

然后按照下面的步骤来重复进行:

然后就找到最后一个复写的数了

特殊情况

当查找最后一个复写的数时cur为0时,我们会发现会出现访问越界的问题,会造成内存泄漏的情况

解决方法也很简单:我们直接将4这个位置也就是n-1变为0,然后再进行cur--,dest-=2

完整步骤:

1. 先找到最后一个复写的数

2. 处理特殊情况

3. 以从右到左的顺序完成复写操作


3. 代码

复制代码
class Solution {
public:
    void duplicateZeros(vector<int>& arr) 
    {
        //1. 先找到最后一个复写的数
        int cur=0,dest=-1,n=arr.size();
        while(cur<n)
        {
            //先判断cur位置的值
             //不为0dest往后移动1步,为0移动2步
            if(arr[cur]) dest++;
            else dest+=2;
            //判断一下dest是否已经到达结束位置
            if(dest>=n-1) break;//n为size,在数组最后一个位置的下一个位置
            //cur++
            cur++;
        }    

        //2. 处理特殊情况 
        //如果dest越界
        if(dest==n)
        {
            arr[n-1]=0;
            cur--;
            dest-=2;
        }

        //3. 以从右到左的顺序完成复写操作
        while(cur>=0)
        {
            //如果cur当前指向的值不为0,那么就直接把cur指向的值写入dest,再同时--
            if(arr[cur]) arr[dest--]=arr[cur--];
            else
            {
                //为0要写2遍
                //然后cur往左移动一位,dest移动2位
                arr[dest--]=0;
                arr[dest--]=0;
                cur--;
            }
        }
    }
};

未完待续~

相关推荐
sin_hielo4 分钟前
leetcode 3637
数据结构·算法·leetcode
仍然.5 分钟前
算法题目---双指针算法
数据结构·算法·排序算法
2401_841495645 分钟前
【LeetCode刷题】翻转二叉树
python·算法·leetcode··递归·节点·翻转二叉树
嵌入小生0079 分钟前
数据结构与算法 | 完全二叉树的实现、哈希表的实现
linux·c语言·数据结构·算法·vim·嵌入式
渡我白衣11 分钟前
无中生有——无监督学习的原理、算法与结构发现
人工智能·深度学习·神经网络·学习·算法·机器学习·语音识别
小龙报12 分钟前
【数据结构与算法】单链表的综合运用:1.合并两个有序链表 2.分割链表 3.环形链表的约瑟夫问题
c语言·开发语言·数据结构·c++·算法·leetcode·链表
蓝海星梦13 分钟前
GRPO 算法演进:2025 年 RL4LLM 领域 40+ 项改进工作全景解析
论文阅读·人工智能·深度学习·算法·自然语言处理·强化学习
拼好饭和她皆失13 分钟前
图论:最小生成树,二分图详细模板及讲解
c++·算法·图论
傻小胖13 分钟前
19.ETH-挖矿算法-北大肖臻老师客堂笔记
笔记·算法·区块链
郝学胜-神的一滴14 分钟前
线性判别分析(LDA)原理详解与实战应用
人工智能·python·程序人生·算法·机器学习·数据挖掘·sklearn