题目: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。
示例:
输入:nums = [1,2,3,4]
输出:[1,3,2,4]
注:[3,1,2,4] 也是正确的答案之一。
解题思路: 看到这道题,我首先想到的是快排中partition的过程,利用partition过程接替即可,两个指针i和j,分别从数组的两边开始遍历,左边遇到偶数,右边遇到奇数的时候,两者进行交换即可。(只是快排中若是升序排序,则左边大于基准值,右边小于基准值时,两者进行交换)
class Solution {
public int[] exchange(int[] nums) {
int i = 0;
int j = nums.length-1;
while(i < j){
while(i < j && (nums[j]%2 == 0)){
j--;
}
while(i < j && (nums[i]%2 != 0)){
i++;
}
swap(nums,i,j);
}
return nums;
}
private void swap(int[] array,int i ,int j){
int temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}