这道题目要求把所有的0元素都放到数组末尾,并且不能改变数组其它元素的相对数序,类似这种题目思维一定要往快慢指针上靠,快指针从头到尾遍历,快指针永远去找非0元素,慢指针则从头开始遍历,找到以后交换俩个元素的位置,然后俩个指针分别往前走一步。注意这里如果慢指针的策略是永远去找0元素的话,那么就会涉及到一些和快指针的比较,只有在慢指针比快指针小的时候所指向的元素才可以交换,cpu时间会更高一点
java
public class moveZeroes {
public static void main(String[] args) {
int[] arr = {0,1,0,3,12};
moveZero(arr);
for(int i = 0;i<arr.length;i++) {
System.out.println(arr[i]);
}
}
public static void moveZero(int[] arr) {
for(int i = 0,j=0;i<arr.length;i++) {
if(arr[i] != 0) {
int tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
j++;
}
}
}
}