You are given an integer array nums, move all the even integers at the beginning of the array followed by all the odd integers.
Return any array that satisfies this condition.
Example 1:
Input: nums = [3,1,2,4]
Output: [2,4,3,1]Explanation: The outputs [4,2,3,1], [2,4,1,3], and [4,2,1,3] would also be accepted.
Example 2:
Input: nums = [0]
Output: [0]Constraints:
1 <= nums.length <= 5000.0 <= nums[i] <= 5000.class Solution:
def sortArrayByParity(self, nums: List[int]) -> List[int]:
nums.sort(key = lambda x: x & 1)
return numsclass Solution:
def sortArrayByParity(self, nums: List[int]) -> List[int]:
even, odd = [], []
for num in nums:
if num & 1:
odd.append(num)
else:
even.append(num)
idx = 0
for e in even:
nums[idx] = e
idx += 1
for o in odd:
nums[idx] = o
idx += 1
return numsclass Solution:
def sortArrayByParity(self, nums: List[int]) -> List[int]:
i, j = 0, len(nums) - 1
while i < j:
if nums[i] & 1:
nums[i], nums[j] = nums[j], nums[i]
j -= 1
else:
i += 1
return numsclass Solution:
def sortArrayByParity(self, nums: List[int]) -> List[int]:
l = 0
for r in range(len(nums)):
if nums[r] % 2 == 0:
nums[l], nums[r] = nums[r], nums[l]
l += 1
return nums