题目大意:
移动零
给定一个数组 nums
,编写一个函数将所有 0
移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入:[0,1,0,3,12]
输出:[1,3,12,0,0]
说明:
- 必须在原数组上操作,不能拷贝额外的数组。
- 尽量减少操作次数。
如果想查看本题目是哪家公司的面试题,请参考以下免费链接: https://leetcode.jp/problemdetail.php?id=283
解题思路分析:
由于题目要求使用原地算法,因此本题的难度稍微有所提高。核心逻辑是,我们首先确定首个0的位置indexZero,在indexZero之前的元素都无须改变位置。indexZero后面第一个出现的非0数字,它的位置要前移至indexZero,而该数字原先的位置须设置为0,同时因为indexZero位置已不再是0,它的下标应该加一。重复上述过程,直到循环完所有数字为止。本题时间复杂度为O(n),空间复杂度为O(1)。
实现代码:
public void moveZeroes(int[] nums) { int firstZero=-1; // 首个0出现的位置,默认是-1,代表还没找到0 for(int i=0;i<nums.length;i++){ // 如果当前数字是0 if(nums[i]==0){ // 如果还没找到首个数字0,那么当前位置即是首个0的位置 if(firstZero==-1) firstZero=i; continue; } // 当前数字不是0的情况 // 如果还没发现数字0,当前数字不需要移动位置 // 如果已经发现首个数字0的位置 if(firstZero!=-1){ // 将首个数字0的位置替换为当前数字 nums[firstZero]=nums[i]; // 当前位置置换为0 nums[i]=0; // 首个数字0的位置加一 firstZero++; } } }
本题解法执行时间为0ms。
Runtime: 0 ms, faster than 100.00% of Java online submissions for Move Zeroes.
Memory Usage: 39.4 MB, less than 43.36% of Java online submissions for Move Zeroes.
本网站文章均为原创内容,并可随意转载,但请标明本文链接如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: https://leetcode.jp/leetcode-283-move-zeroes-解题思路分析/