剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。
示例:
输入:nums = [1,2,3,4]
输出:[1,3,2,4]
注:[3,1,2,4] 也是正确的答案之一。
解题思路
public int[] exchange(int[] nums) {
int left = 0, right = nums.length - 1;
while (left < right) {
// 找到左边的第一个偶数
while ((nums[left] & 0x01) == 1 && left < right) {
left++;
}
// 找到右边的第一个奇数
while ((nums[right] & 0x01) == 0 && left < right) {
right--;
}
// 将左右两边的奇偶数交换
if (left < right) {
swap(nums, left, right);
}
}
return nums;
}
public void swap(int[] nums, int index1, int index2) {
int temp = nums[index1];
nums[index1] = nums[index2];
nums[index2] = temp;
}
上面是一种首尾双指针的写法
下面是一种快慢双指针的写法
public int[] exchange(int[] nums) {
int low = 0, fast = 0;
while (fast < nums.length) {
if ((nums[fast] & 0x1) == 1) {
swap(nums, low, fast);
low++;
}
fast++;
}
return nums;
}