每日算法【双指针算法】(Day 2-复写零)

双指针算法

1.算法题目(复写零)

注意:不要越界,不能开额外的数组,只能从现有数组上进行操作,没有返回值。

2.讲解算法原理

解法 :双指针操作

先根据"异地"操作,然后优化成双指针的"就地"操作。

  • 先找到最后一个"复写"的数;
  • 双指针算法
    解释:用一个数组,让cur指向下标为0的位置,让dest指向下标为-1的位置,判断cur指向的元素是否为零,不为零dest向后移动一位,判断dest是否移动到最后一位,没有就再次移动cur一位,如果cur指向的元素为零,就要dest向后移动两位,再判断dest是否结束,结束就知道复写数组最后一个元素是什么。
  • 先判断cur位置的值
  • 决定dest向后移动一步或者两步
  • 判断一下dest是否已经到结束为止
  • cur++
  1. 处理一下边界情况
    因为dest可能存在越界的情况
cpp 复制代码
n-1=0;
cur--;
dest-=2;
  1. "从后向前"完成复写操作;
    因为我们已经知道最后一个元素是什么了,"从后往前"复写也不会存在覆盖的情况。

3.编写代码

cpp 复制代码
class Solution {
public:
    void duplicateZeros(vector<int>& arr) 
    {
        //1.先找最后一个元素
        int cur = 0, dest = -1, n = arr.size();
        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--;
            }
        }

    }
};
相关推荐
Humbunklung1 小时前
Rust 控制流
开发语言·算法·rust
ghost1431 小时前
C#学习第27天:时间和日期的处理
开发语言·学习·c#
jason成都1 小时前
c#压缩与解压缩-SharpCompress
开发语言·c#
鑫鑫向栄2 小时前
[蓝桥杯]取球博弈
数据结构·c++·算法·职场和发展·蓝桥杯·动态规划
傻啦嘿哟2 小时前
从零开始:用Tkinter打造你的第一个Python桌面应用
开发语言·c#
m0_634448892 小时前
从上下文学习和微调看语言模型的泛化:一项对照研究
学习·算法·语言模型
三十一6143 小时前
6.4 C++作业
开发语言·c++
Once_day3 小时前
代码训练LeetCode(21)跳跃游戏2
算法·leetcode
CodeCraft Studio3 小时前
PDF处理控件Aspose.PDF教程:在 C# 中更改 PDF 页面大小
前端·pdf·c#
InCerry4 小时前
.NET周刊【5月第4期 2025-05-25】
c#·.net·.net周刊