1089. 复写零
Posted mustard22
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了1089. 复写零相关的知识,希望对你有一定的参考价值。
给你一个长度固定的整数数组 arr,请你将该数组中出现的每个零都复写一遍,并将其余的元素向右平移。 注意:请不要在超过该数组长度的位置写入元素。 要求:请对输入的数组 就地 进行上述修改,不要从函数返回任何东西。 示例 1: 输入:[1,0,2,3,0,4,5,0] 输出:null 解释:调用函数后,输入的数组将被修改为:[1,0,0,2,3,0,0,4] 示例 2: 输入:[1,2,3] 输出:null 解释:调用函数后,输入的数组将被修改为:[1,2,3] 提示: 1 <= arr.length <= 10000 0 <= arr[i] <= 9 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/duplicate-zeros
代码如下:
时间复杂度O(n),空间复杂度O(1)。
1 func duplicateZeros(_ arr: inout [Int]) 2 // 数组为空 或 只有1个元素时,直接返回 3 if arr.count < 2 4 return 5 6 7 // 本次遍历目的:找出可复写0的个数 8 var i = 0, j = 0 9 while j < arr.count 10 if arr[i] == 0 11 j += 1 12 13 i += 1 14 j += 1 15 16 17 // 没有元素为0; 18 if i == j 19 return 20 21 // 当且仅当最后一个元素为0 22 else if i == arr.count-1 && j > arr.count 23 return 24 25 26 // i,j回到下次遍历的开始位置 27 i -= 1 28 j -= 1 29 while i >= 0 30 if j < arr.count 31 arr[j] = arr[i] 32 33 if arr[i] == 0 34 j -= 1 35 arr[j] = arr[i] 36 37 38 i -= 1 39 j -= 1 40 41
以上是关于1089. 复写零的主要内容,如果未能解决你的问题,请参考以下文章