算法002——复写零

力扣------复写零点击即可跳转

这道题还是运用 双指针,我们从左往右开始,让 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 向前移动一位,然后继续完成复写操作。

代码如下

java 复制代码
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--;
            }
        }
    }
}

今天累成菜狗了,什么都没学到,起码累到了

相关推荐
_x_w5 分钟前
【17】数据结构之图及图的存储篇章
数据结构·python·算法·链表·排序算法·图论
anscos12 分钟前
Actran声源识别方法连载(二):薄膜模态表面振动识别
人工智能·算法·仿真软件·actran
-优势在我34 分钟前
LeetCode之两数之和
算法·leetcode
WaitWaitWait0138 分钟前
LeetCode每日一题4.17
算法·leetcode
小媛早点睡38 分钟前
贪心算法day9(合并区间)
算法·贪心算法
DataFunTalk1 小时前
Foundation Agent:深度赋能AI4DATA
前端·后端·算法
不是AI1 小时前
【Java编程】【计算机视觉】一种简单的图片加/解密算法
java·算法·计算机视觉
明月看潮生1 小时前
青少年编程与数学 02-016 Python数据结构与算法 23课题、分布式算法
分布式·python·算法·青少年编程·编程与数学
冠位观测者2 小时前
【Leetcode 每日一题】2176. 统计数组中相等且可以被整除的数对
数据结构·算法·leetcode
幼儿园园霸柒柒2 小时前
第七章:7.2求方程a*x*x+b*x+c=0的根,用3个函数,分别求当:b*b-4*a*c大于0、等于0和小于0时的根并输出结果。从主函数输入a、b、c的值
c语言·开发语言·算法·c#