题目描述
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
思路
最直观的方法:先统计出奇数的个数,然后建个新数组,遍历原数组,根据奇数偶数判断在新数组中存放的位置:
若是奇数:直接从新数组第一个位置开始放
若是偶数:让出奇数的位置(对应得到的奇数个数),再逐个放进去
最后把新数组的元素再赋值给原数组,即完成题目要求
实现
public void reOrderArray(int [] array) {
/*先遍历数组统计出奇数个数
新建一个和array等长的数组,
遍历array,遇到奇数就从头开始放进新数组‘遇到偶数就从奇数总数下一个位置开始放
*/
int oddNum=0;
int oddStart=0; //奇数开始的位置(初始就是第一个)
for(int i=0;i<array.length;i++){
if(array[i]%2==1){
oddNum++;
}
}
//新建一个等长数组来存放想要的序列
int[] newArray=new int[array.length];
//遍历,判断放进新数组的位置
for(int i=0;i<array.length;i++){
if(array[i]%2==1){ //若是奇数,直接从第一个位置开始向后放
newArray[oddStart++]=array[i];
}
else{ //若是偶数,让出奇数的位置,从奇数后面开始放
newArray[oddNum++]=array[i];
}
}
//最后再把新数组的元素赋给原数组
for(int i=0;i<newArray.length;i++){
array[i]=newArray[i];
}
}
时间复杂度和空间复杂度都是O(n),相比网友们说的排序算法要快很多,算是牺牲空间来换取时间吧