代码:
class Solution {
public void swap(int[] nums,int m,int n){
int tmp=nums[m];
nums[m]=nums[n];
nums[n]=tmp;
}
public void moveZeroes(int[] nums) {
int cur=0;
int dest=-1;
int n=nums.length;
for(;cur<n;cur++){
if(nums[cur]!=0){
dest++;
swap(nums,cur,dest);
}
}
}
}
题解:
根据题意,我们要将数组进行处理,分为 非0 的区间和 全为0 的区间
现在我们通过 cur 指针遍历数组并按相关规则对数据进行处理,遍历过的区间是 已处理 区间,还未遍历的区间是未处理区间,而 已处理 区间中又分为 非0 的区间和 全为0 的区间,我们设定 dest 指针指向最后一个非0数据
这样划分,当 cur 指针遍历完数组以后,数组就被 dest 指针划分成了题意中左边为非 0 元素,右边为 0 的结构
我们让 cur 指针(并不是真的指针,方便理解才这样说)指向下标 0,用来遍历数组,dest 指针指向下标 -1 ,因为 dest 指针的含义是指向最后一个非 0 数据,而现在 cur 指针还没有遍历到非 0 数据,所以先指向 -1
cur 指针向后遍历的时候会遇到两种情况:
1.cur 指针遇到 0
根据上面的图以及分析,我们知道,0 应该在指针 dest 和 cur 之间,所以我们得出,当 nums[cur]==0 –> cur++;
2.cur 指针遇到非 0 数据
由于 dest 指针要指向最后一个非 0 数据,所以 dest 首先要 ++,为该非 0 数据提供一个空位,此时 dest 指针指向的是 0 数据,cur 指针指向的是非 0 的数据,于是将 cur 和 dest 指针指向的数据进行交换
我们得到关系,当 nums[cur]!=0 –> dest++ , swap(nums[cur],nums[dest]) , cur++
原文地址:https://blog.csdn.net/q322359/article/details/134667359
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_6653.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!