python调整数组顺序使奇数位于偶数前面

2021/12/26 1:07:18

本文主要是介绍python调整数组顺序使奇数位于偶数前面,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

|调整数组顺序使奇数位于偶数前面

输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数在数组的前半部分,所有偶数在数组的后半部分。

示例:

输入: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


这篇关于python调整数组顺序使奇数位于偶数前面的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程