调整数组顺序使得奇数位于偶数之前。调整之后,不关心大小顺序。
如数组:[1,2,3,4,5,6]
调整后可能是:[1, 5, 3, 4, 2, 6]
public static void func(int[] array) {
int left = 0;
int right = array.length-1;
while (left < right) {
while (array[left] % 2 != 0) {
left++;
}
while (array[right] % 2 == 0) {
right--;
}
int tmp = array[left];
array[left] = array[right];
array[right] = tmp;
}
}
public static void main(String[] args) {
int[] array = {1,2,3,4,5,6};
func(array);
System.out.println(Arrays.toString(array));
}
运行结果如下:
可以看出,上面的代码还有一点小问题。
修改如下:
public static void func(int[] array) {
int left = 0;
int right = array.length-1;
while (left < right) {
while (left < right && array[left] % 2 != 0) {
left++;
}
while (left < right && array[right] % 2 == 0) {
right--;
}
int tmp = array[left];
array[left] = array[right];
array[right] = tmp;
}
}
public static void main(String[] args) {
int[] array = {1,2,3,4,5,6};
func(array);
System.out.println(Arrays.toString(array));
}