输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
1.暴力破解法
import java.util.*;
public class Solution {
public void reOrderArray(int [] a) {
if(a==null || a.length ==0){
return ;
}
//a3存放奇数,a2存放偶数
ArrayList<Integer> a3 = new ArrayList<Integer>();
ArrayList<Integer> a2 = new ArrayList<Integer>();
for(int i = 0,count = 0; i < a.length; i++){
if(a[i] % 2 != 0){
a3.add(a[i]);
}else{
a2.add(a[i]);
}
}
Integer[] b1 = a3.toArray(new Integer[a3.size()]);
Integer[] b2 = a2.toArray(new Integer[a2.size()]);
for(int i = 0; i < b1.length; i++){
a[i] = b1[i];
}
for(int i = 0,j = b1.length; i < b2.length; i++,j++){
a[j] = b2[i];
}
}
}2.参考快速排序
class Solution {
public:
void reOrderArray(vector<int> &array) {
int len = array.size();
if(len <= 1){ // 数组空或长度为1
return;
}
int i = 0;
while(i < len){
int j = i + 1;
if(array[i]%2 == 0){ // a[i]为偶数,j前进,直到替换
while(array[j]%2 == 0){ // j为偶数,前进
if(j==len-1)// i为偶数,j也为偶数,一直后移到了末尾,证明后面都是偶数
return;
j++;
}
// 此时j为奇数
int count = j-i;
int temp = array[i];
array[i] = array[j];
while(count>1){
array[i+count] = array[i+count-1];//数组后移
count--;
}
array[i+1] = temp;
}
i++;
}
}
};
京公网安备 11010502036488号