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

    }
};
相关推荐
不知天地为何吴女士1 小时前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界1 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
liulilittle2 小时前
C++ TAP(基于任务的异步编程模式)
服务器·开发语言·网络·c++·分布式·任务·tap
励志要当大牛的小白菜4 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970444 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵5 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
唐青枫5 小时前
C#.NET dapper 详解
c#·.net
爱喝矿泉水的猛男7 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao7 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
死也不注释7 小时前
【鸡零狗碎记录】
unity·c#