输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
不需要额外空间,时间复杂度O(n2),冒泡排序思想
public class Solution {
public void reOrderArray(int [] a) {
for(int i=0;i<a.length;i++){
if(a[i]%2==1){
for(int j=i-1;j>=0;j--){
if(a[j]%2==0){
int temp = a[j+1];//important
a[j+1] = a[j];
a[j] = temp;
}else{
break;
}
}
}
}
}
}
需要额外空间,空间复杂度O(n)
新建两个数组存储分别存储奇数和偶数