【LeetCode刷题之路】283:移动零的普通解法与优化解法(含动图演示)
LeetCode刷题记录 |
- 🌐 我的博客主页:iiiiiankor
- 🎯 如果你觉得我的内容对你有帮助,不妨点个赞👍、留个评论✍,或者收藏⭐,让我们一起进步!
- 📝 专栏系列:LeetCode 刷题日志
- 🌱 文章内容来自我的学习与实践经验,如果你有任何想法或问题,欢迎随时在评论区交流讨论。让我们一起探索更多的可能!🚀
文章目录
- 📜题目描述
- 💡解题思路
📜题目描述
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
请注意 ,必须在不复制数组的情况下原地对数组进行操作。
示例1
输入: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]
示例2
输入: nums = [0]
输出: [0]
提示:
- 1 <= nums.length <= 10^4
- -2^31 <= nums[i] <= 2^31 - 1
💡解题思路
这个题有两种大思路,第二种有一个原版本,有一个优化版本
解法1
在i位置遇到0,把后面的元素向前移动覆盖,然后把最后一个位置赋值为0即可
注意问题:
可能 i 一个位置 移动一次之后还是0,需要循环
有可能 i 位置的0 是因为 已经所有的0都到后面了
所以需要用count记录0的个数,当所有0都移动完了就break,否则会死循环
代码1
解法2 (效率高)
双指针法
end去找非0,放到src位置
最后end走到numsSize,src位置就是最后一个非0的下一个位置
把src后面的置0
最后:
代码2
解法2优化:不用memset,直接在过程中交换
当end位置为非0的时候
其实可以直接把src位置和end位置的元素进行交换
如图:
可以发现 src和end交换的过程就是一直把0向后换
如果数组没有0
那么src和end一直自己交换,也是正确的!
总结:
src和end位置交换
- 要么就是把0向后换
- 要么就是自己与自己交换
代码3