力扣——复写零点击即可跳转
这道题还是运用 双指针,我们从左往右开始,让 cur = 0,dest = 0,当我们循环时,会覆盖后面的值,所以从左到右无法实现,我们运用 从右到左的方式。
以示例一数组为例,从输出结果我们可以知道最后一个复写的数为 4,我们先让 cur 指向 4 的位置,让 dest 从数组的最后一个位置 从右往左 走
cur 会遇到两种情况
- cur 指向的值为 非零元素
此时,我们让 dest 指向的值 等于 cur 指向的值
两个指针一起向前移动一位 - cur 指向的值 为 零
此时,我们将 dest 指向的值 和 dest 前一个位置的值 都改为 零
也就是说 cur 的位置为 0 时,dest 往前移动两位
下一步,找到 复写的最后一个数
还是使用双指针,dest 初始化为 -1 ,让 cur 从下标 0 开始遍历数组
此时 cur 有两种情况
- cur 指向 非零
dest 向右移动一位 - cur 指向 零
dest 向右移动两位
当 dest 指向最后的位置时,cur 所指向的位置就是 复写最后一个数
在 cur++ 前,我们要判断 dest 是否越界,当 cur 指向 零 时,而 dest 此时正在数组的最后一个位置,这个情况 dest 向右移动两位会越界。
当我们出现 越界 情况时, 此时一定是因为 cur 指向 零 导致的,此时我们将最后一个位置修改成 零 ,然后让 dest 向前移动两位, cur 向前移动一位,然后继续完成复写操作。
代码如下
class Solution { public void duplicateZeros(int[] arr) { //1.首先找到最后一个复写的数 int cur = 0; int dest = -1; while(cur < arr.length){ if(arr[cur] == 0){ dest+=2; }else{ dest++; } if(dest >= arr.length - 1){ break; } cur++; } //2.处理边界,此时越界,越界情况只可能为0 if(dest == arr.length){ arr[arr.length - 1] = 0; dest-=2; cur--; } //3.从后向前完成复写操作 while(cur >= 0){ if(arr[cur] != 0){ arr[dest] = arr[cur]; dest--; cur--; }else{ arr[dest] = 0; dest--; arr[dest]= 0; dest--; cur--; } } } }
复制
今天累成菜狗了,什么都没学到,起码累到了