输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数在数组的前半部分,所有偶数在数组的后半部分。
示例:
输入:nums = [1,2,3,4]
输出:[1,3,2,4]
注:[3,1,2,4] 也是正确的答案之一。
提示:
0 <= nums.length <= 50000
0 <= nums[i] <= 10000
class Solution: """ 解题思路: 1.双指针解法 p指针正序遍历 q指针倒序遍历 2.如果p指针遇到偶数,q指针遇到奇数就交换位置 """ def exchange(self, nums: List[int]) -> List[int]: length = len(nums) p, q = 0, length - 1 while q > p: # 当前p指针指向为奇数 就向后移位 if nums[p] % 2 == 1: p += 1 # 当前q指针指向为偶数 就向前移位 elif nums[q] % 2 == 0: q -= 1 # 以上条件都不满足 交换双方位置 else: nums[p], nums[q] = nums[q], nums[p] return nums