每日算法【双指针算法】(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--;
            }
        }

    }
};
相关推荐
CoovallyAIHub19 分钟前
方案 | 动车底部零部件检测实时流水线检测算法改进
深度学习·算法·计算机视觉
CoovallyAIHub22 分钟前
方案 | 光伏清洁机器人系统详细技术实施方案
深度学习·算法·计算机视觉
Dm_dotnet23 分钟前
Stylet启动机制详解:从Bootstrap到View显示
c#
lxmyzzs26 分钟前
【图像算法 - 14】精准识别路面墙体裂缝:基于YOLO12与OpenCV的实例分割智能检测实战(附完整代码)
人工智能·opencv·算法·计算机视觉·裂缝检测·yolo12
洋曼巴-young27 分钟前
240. 搜索二维矩阵 II
数据结构·算法·矩阵
汉汉汉汉汉40 分钟前
C++11新特性详解:从列表初始化到线程库
c++
楼田莉子2 小时前
C++算法题目分享:二叉搜索树相关的习题
数据结构·c++·学习·算法·leetcode·面试
三千道应用题2 小时前
WPF&C#超市管理系统(6)订单详情、顾客注册、商品销售排行查询和库存提示、LiveChat报表
开发语言·c#·wpf
pusue_the_sun3 小时前
数据结构——栈和队列oj练习
c语言·数据结构·算法··队列
大锦终3 小时前
【算法】模拟专题
c++·算法