题目描述:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
思路:1.借助两个动态数组,一个存放奇数,一个存放偶数,然后将两个数组按奇数在前偶数在后合并,放回原数组。
2.类似于冒泡排序,偶数和奇数逆序就交换。
代码1:
import java.util.*;
public class Solution {
public void reOrderArray(int [] array) {
ArrayList<Integer> sup1 = new ArrayList<>();
ArrayList<Integer> sup2 = new ArrayList<>();
for(int i = 0; i < array.length; i++){
if(array[i] % 2 == 1){
sup1.add(array[i]);
}else{
sup2.add(array[i]);
}
}
sup1.addAll(sup2);
for(int i = 0; i < array.length; i++){
array[i] = sup1.get(i);
}
}
}
代码2:
public class Solution {
public void reOrderArray(int [] array) {
for(int i = 0; i < array.length - 1; i++){
for(int j = 0; j < array.length - 1; j++){
if(array[j] % 2 == 0 && array[j + 1] % 2 == 1){
int temp = array[j];
array[j] = array[j + 1];
array[j + 1] = temp;
}
}
}
}
}