题目描述
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
题解
为了保持相对位置不变,可以采用稳定排序,比如插入排序。
public class Solution {
public void reOrderArray(int [] a) {
for(int i=1;i<a.length;i++) {
for(int j=i;j>0 && a[j] % 2 == 1 && a[j-1] % 2 == 0;j--) {
int temp = a[j];
a[j] = a[j-1];
a[j-1] = temp;
}
}
}
}