欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 明星 > 【优选算法】复写零

【优选算法】复写零

2025/2/25 14:31:54 来源:https://blog.csdn.net/weixin_74146322/article/details/144669670  浏览:    关键词:【优选算法】复写零

链接:1089. 复写零 - 力扣(LeetCode)

算法原理:

解法:双指针算法

根据“异地”操作,然后优化成双指针下的“就地”操作

1.先找到最后一个“复写”的数

        1.先判断 cur 位置的值

        2.决定 dest 向后移动一步或者两步

        3.判断一下 dest 是否已经到结束为止

        4.cur++;

        5.处理一下边界情况: n-1 = 0;

                                            cur--;

                                            dest -= 2;

2.“从后向前”完成复写操作

代码如下:

class Solution {public void duplicateZeros(int[] arr) {int cur = 0, dest = -1, n = arr.length;//1.先找到最后一个需要复写的数while(cur < n){if(arr[cur] == 0){dest += 2;}else{dest += 1;}if(dest >= n-1){break;}cur++;}//2.处理一下边界情况if(dest == n){arr[n-1] = 0;cur--;dest -=2;}//3.从后向前完成复写while(cur >= 0){if(arr[cur] != 0){arr[dest--] = arr[cur--];}else{arr[dest--] = 0;arr[dest--] = 0;cur--;}}}
}

复杂度分析:

  • 时间复杂度:O(n),虽然是两个while循环,但是常数部分可以忽略不计,相当于遍历一遍数组就完成了
  • 空间复杂度:O(1)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词