算法题001——移动零
- 游戏开发
- 2025-09-21 14:54:01

移动零
力扣——移动零点击链接即可跳转
这道题的数组被划分为两个区间,前一个区间为 非零元素,而后一个指针是 零元素 我们运用双指针,先定义两个指针,分别为 dest 和 cur , cur用来遍历整个数组,而 dest 表示我们已经处理完的数组的最后一个位置。 当连个指针往前走的时候,整个数组被划分为三个部分 cur 前为 处理完的部分,cur 后为 未处理的部分 而 dest 前为 非零部分, dest 后为 零
首先,定义 cur 从0 位置开始遍历,此时,并没有处理完的部分,所以定义 dest = -1;
当 cur 的位置等于 0 时,我们让 cur++ 当 cur 的位置不等于 0 时,我们让 dest++ ,并将 dest 位置的值 与 cur 位置的值互换
首先,定义 cur 从0 位置开始遍历,此时,并没有处理完的部分,所以定义 dest = -1;
cur 遍历的时候会遇到两种情况
当 cur 的位置等于 0 不做任何处理当 cur 的位置不等于 0 遇到非零元素,我们想让非零元素到最左边,此时我们让 dest++ ,并将 dest 位置的值 与 cur 位置的值互换即可实现这就是这道题的原理,下面是代码实现
class Solution { public void moveZeroes(int[] nums) { for(int cur = 0,dest = -1;cur < nums.length;cur++){ if(nums[cur] != 0){ dest++; swap(nums,dest,cur); } } } private void swap(int[] array,int i,int j){ int tmp = array[i]; array[i] = array[j]; array[j] = tmp; } }觉得有用的给我点个赞,有用还不点赞的击毙处理,承受仔仔的子弹吧
算法题001——移动零由讯客互联游戏开发栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“算法题001——移动零”