输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。
示例:
输入:nums = [1,2,3,4]
输出:[1,3,2,4]
注:[3,1,2,4] 也是正确的答案之一。
提示:
1 <= nums.length <= 50000
1 <= nums[i] <= 10000
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/diao-zheng-shu-zu-shun-xu-shi-qi-shu-wei-yu-ou-shu-qian-mian-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解答:
简单的开辟新空间的解法为 新建奇偶数组 遍历分别插入值。
最后返回数组+的值即可。
代码简单 略
思考:
不开辟新的空间:
使用双指针
1 双指针起点 i前 j后
2 如果j为奇数,则与i交换,i+=1,(交换过来可能为偶数,要再检查一遍)
3 如果i=j 则j+=1
4 正常则j+=1继续
代码:
class Solution:
def exchange(self, nums: List[int]) -> List[int]:
if len(nums)<=1:
return nums
i = 0
j = 1
while i<=len(nums)-1 and j<=len(nums)-1:
#print(i,j)
if i == j :
j+=1
continue
if nums[j]%2==1:
nums[i],nums[j]=nums[j],nums[i]
i+=1
continue
j+=1
return nums
扩展:
不扩展空间,并且保证奇偶数的顺序一致。
解答:
交换排序的思想
1 起点i遍历,遇到偶数停止
2 进入循环j=i+1,自增直到找到奇数。
3 [i,j-1]的部分整体右移,将j位的放在头部
代码:
class Solution:
def exchange(self, nums):
i = 0
j = 0
while i <len(nums) and j<len(nums):
if nums[i]%2==0:
j=i+1
while j<len(nums):
if nums[j]%2==1:
#x = nums[j]
nums[i+1:j+1],nums[i] = nums[i:j],nums[j]
j+=1
i+=1
else:
j+=1
else:
i+=1
return nums