算法002:复写零

力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/duplicate-zeros/

使用 双指针 来解题:

具体思路

如果是和001题一样的,使用双指针从前往后扫描,并且修改相关的值的话,会出现某些值被覆盖,不能完成题目要求。于是我们采用双指针从后往前覆写。

分为三步走:

1.让双指针从左往右扫描,让右指针遍历数组,左指针遇见非0的数就向右+1,遇见0的数就向右+2。这样做的目的是让两个指针能够刚好停在一个位置,这个位置的左边是保留下来的数字,这个位置的右边是舍弃掉的数字

2.处理特殊情况。如果在数组倒数第二个数,则会出现L指针超过数组的长度的情况

此时要处理这种特殊的情况,把R和L中间的元素变成0,并且让R和L都往前移动一个。此时再继续进行下一步。

3.从后往前覆写。当R位置不为0的时候,让R和L都向左移动就可以了。当R位置的值为0的时候,让L的位置也变成0,并且让R--,L-=2。因为在第一步已经规定了两个指针对应的位置,所以L一次性向左移动两个位置也不会出现位置错乱的情况。

代码:

java 复制代码
class Solution {
    public void duplicateZeros(int[] arr) {
        int left = -1;
        int right = 0;
        int n = arr.length;
        //1.先让left和right都到应该到的位置
        while(right < n){
            if(arr[right] == 0){
                left += 2;
            }else{
                left++;
            }
            if(left >= n-1){
                break;
            }
            right++;
        }
        //2.处理特殊情况
        if(left == n){
            arr[n-1] = 0;
            left -= 2;
            right--;
        }
        //3.从后往前覆写
        while(right >= 0){
            if(arr[right] != 0){
                arr[left--] = arr[right--];
            }else{
                arr[left--] = 0;
                arr[left--] = 0;       
                right--;
            }
        }
    }
}
相关推荐
一切皆是因缘际会12 分钟前
从概率拟合到内生心智:2026 下一代 AI 架构演进与落地实践
人工智能·深度学习·算法·架构
Java成神之路-13 分钟前
【LeetCode 刷题笔记】34. 在排序数组中查找元素的第一个和最后一个位置 | 二分查找经典刷题题解
算法·leetcode
不忘不弃17 分钟前
用BFS方法求解平分汽油问题
算法·宽度优先
AI科技星30 分钟前
全域数学·72分册·射影原本 无穷维射影几何卷细化子目录【乖乖数学】
人工智能·线性代数·算法·机器学习·数学建模·数据挖掘·量子计算
风落无尘37 分钟前
《智能重生:从垃圾堆到AI工程师》——第四章 变化的艺术
人工智能·线性代数·算法
JAVA面经实录91744 分钟前
计算机基础(完整版·超详细可背诵)
java·linux·数据结构·算法
AC赳赳老秦1 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
WBluuue1 小时前
Codeforces 1093 Div2(ABCD1D2)
c++·算法
浅念-1 小时前
「一文吃透 BFS:从层序遍历到锯齿形、最大宽度、每层最大值」
数据结构·算法
汉克老师1 小时前
GESP5级C++考试语法知识(十三、贪心算法(一))
算法·贪心算法·海盗船·gesp5级·gesp五级·排队接水