Problem: 1089. 复写零
首先我们来分析一下本题的题目意思
那在下面我们就去考虑一下在数组原地的操作
cur
遍历到0的话就进行两次的复写操作,不过呢大家可以看到在第一次的复写操作完成之后,【2】被覆盖了,但是这个【2】是我们需要的,那也就造成了一定的问题那么反应快的同学可以意识到,如果要进行覆盖操作的话就需要 从后往前 进行遍历操作才可以
好,接下去呢我们就来分析一下解决本题的思路
dest
指向最后的0那要怎么去找呢?(头一次尝试幻灯片≧ ﹏ ≦)
可以分为以下几步:
但是呢,就上面这样的逻辑去走的话其实是不对的,因为我们还未考虑到特殊的边界情况
dest
又刚好到这个位置,那么就需要向后移动两步,此时就造成了越界问题所以此时我们应该要考虑处理一下这个边界问题
cur
和dest
也需要去做一个变化,cur
前移一位即可,dest
因为做了复写操作,所以需要前移两位上面呢,我们已经找到了需要复写的最后一个位置,那接下去我们就要正式开始复写操作了
cur
位置开始,慢慢地向前遍历然后去做复写操作即可,将数一一地复写到dest
所在的位置,如果arr[cur]
为0的话,那我们就需要考虑复写两次了最后来展示一下整体的代码
class Solution {
public:
void duplicateZeros(vector<int>& arr) {
// 1.找到复写的最后一个位置
// (1) 判断cur位置的值,决定dest走一步还是两步
// (2) 判断dest是否到达末尾,决定cur是否++
int dest = -1;
int cur = 0;
int sz = arr.size();
while(dest < sz)
{
if(arr[cur]) dest++;
else dest += 2;
if(dest >= sz - 1)
break;
cur++;
}
// 2.判断边界的情况
if(dest == sz)
{
arr[dest - 1] = 0;
cur--;
dest -= 2;
}
// 3.从右往左复写0
while(cur >= 0)
{
if(arr[cur]) arr[dest--] = arr[cur--];
else
{
arr[dest--] = 0;
arr[dest--] = 0;
cur--;
}
}
}
};
下面是运行后的结果