LeetCode 1089.复写零

题目

给你一个长度固定的整数数组 arr ,请你将该数组中出现的每个零都复写一遍,并将其余的元素向右平移。

注意:请不要在超过该数组长度的位置写入元素。请对输入的数组 就地进行上述修改,不要从函数返回任何东西。

思路

代码

java 复制代码
class Solution {
    public void duplicateZeros(int[] arr) {
        int n = arr.length;
        int cnt0 = 0;
        for (int i = 0; i < n; i++) {
            if (arr[i] == 0) {
                cnt0++;
            }
        }
        for (int j = n - 1; j >= 0; j--) {
            if (arr[j] == 0) {
                cnt0--;
            }
            if (j + cnt0 < n) {
                arr[j + cnt0] = arr[j];
            }
            if (arr[j] == 0 && j + cnt0 + 1 < n) {
                arr[j + cnt0 + 1] = 0;
            }
        }
    }
}

性能

时间复杂度o(n)

空间复杂度o(1)

相关推荐
与己斗其乐无穷2 小时前
算法(一)双指针法
数据结构·算法·排序算法
(❁´◡`❁)Jimmy(❁´◡`❁)3 小时前
【Trie】 UVA1401 Remember the Word
算法·word·图论
高山有多高5 小时前
从 0 到 1 保姆级实现C语言双向链表
c语言·开发语言·数据结构·c++·算法·visual studio
今后1235 小时前
【数据结构】冒泡、选择、插入、希尔排序的实现
数据结构·算法·排序算法
草莓熊Lotso6 小时前
《算法闯关指南:优选算法--滑动窗口》--14找到字符串中所有字母异位词
java·linux·开发语言·c++·算法·java-ee
hhhhhshiyishi6 小时前
WLB公司内推|招联金融2026届校招|18薪
java·算法·机器学习·金融·求职招聘
MATLAB代码顾问6 小时前
Python实现手榴弹爆炸算法(Grenade Explosion Method, GEM)(附完整代码)
开发语言·python·算法
SuperCandyXu7 小时前
P2168 [NOI2015] 荷马史诗-提高+/省选-
数据结构·c++·算法·洛谷