剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
一、题目详情
原题链接:剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。
示例:
输入:nums = [1,2,3,4]
输出:[1,3,2,4]
注:[3,1,2,4] 也是正确的答案之一。
提示:
0 <= nums.length <= 50000
1 <= nums[i] <= 10000
二、哈希表法
class Solution {
public int[] exchange(int[] nums) {
//奇数list
List<Integer> oddList = new ArrayList<>();
//偶数list
List<Integer> evenList = new ArrayList<>();
for(int i = 0;i < nums.length;i++){
//遍历数组将数组中的奇数和偶数分别放入奇数list和偶数list
if(nums[i] % 2 == 0){
evenList.add(nums[i]);
}else{
oddList.add(nums[i]);
}
}
for(int i = 0;i < oddList.size();i++){
//先将nums的前oddList.size()个数全部重置为原nums中的奇数
nums[i] = oddList.get(i);
}
for(int i = 0;i < evenList.size();i++){
//接着oddList.size(),把剩下的nums全部置为原nums中的偶数
nums[oddList.size() + i] = evenList.get(i);
}
return nums;
}
}
三、双指针法
class Solution {
public int[] exchange(int[] nums) {
//设置双指针
int i = 0,j = nums.length - 1;
/*
1.当nums[i]为偶数时
1.1当nums[j]为奇数时,二者交换,指针i前移,指针j后移
1.2当nums[i]为偶数时,指针j后移
2.当nums[i]为奇数时,指针i前移
*/
while(i <= j){
if(nums[i] % 2 == 0){
if(nums[j] % 2 != 0){
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
i++;
j--;
}else{
j--;
}
}else{
i++;
}
}
return nums;
}
}