一、复写零

二、思路分析
复写零这道题是让在原数组修改,如果从前向后遍历,后面的元素会被覆盖,所以我们要找到被复写的最后一个元素,然后从后往前复写。运用双指针 + 逆向填充。
1. 找到复写的最后一个数
定义两个指针:cur 遍历原数组,pre 模拟复写后的数组指针;cur==0 时,pre 向后移动两位,cur!=0 时,pre 向后移动一位(逻辑上对应复写后的位置);当 pre>=n-1 时,停止遍历,这时,cur 指的就是要复写的最后一个元素。

边界情况:如下面这种情况,pre == n 时,说明要复写的最后一个元素是 0,这里单独处理。
将数组最后一位改为 0,也就是 n==0;cur 向前移动一位,pre 向前移动两位。

2. 开始从后往前复写
从 cur 向前遍历,cur != 0 时,就让 arr[pre] == arr[cur]; cur == 0 时,就让 pre 和 pre-1 位置的数都改为 0,然后继续向前复写。



