我是靠谱客的博主 缥缈朋友,最近开发中收集的这篇文章主要介绍【Python】【难度:简单】Leetcode 922. 按奇偶排序数组 II【完】,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

给定一个非负整数数组 A, A 中一半整数是奇数,一半整数是偶数。

对数组进行排序,以便当 A[i] 为奇数时,i 也是奇数;当 A[i] 为偶数时, i 也是偶数。

你可以返回任何满足上述条件的数组作为答案。

 

示例:

输入:[4,2,5,7]
输出:[4,5,2,7]
解释:[4,7,2,5],[2,5,4,7],[2,7,4,5] 也会被接受。
 

提示:

2 <= A.length <= 20000
A.length % 2 == 0
0 <= A[i] <= 1000

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/sort-array-by-parity-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

思路1

额外空间分别存储奇数和偶数,再分次序添加

class Solution(object):
    def sortArrayByParityII(self, A):
        """
        :type A: List[int]
        :rtype: List[int]
        """
        res1=[]
        res2=[]
        res=[]
        for i in A:
            if i%2:
                res1.append(i)
            else:
                res2.append(i)
        for i in range(len(res1)):
            res.append(res2[i])
            res.append(res1[i])
        return res

执行结果:

通过

显示详情

执行用时 :192 ms, 在所有 Python 提交中击败了96.97%的用户

内存消耗 :14.7 MB, 在所有 Python 提交中击败了25.00%的用户

 

思路2

双指针法,指针i指向偶数位置,指针j指向奇数位置

class Solution(object):
    def sortArrayByParityII(self, A):
        """
        :type A: List[int]
        :rtype: List[int]
        """
        i = 0
        j = 1
        while i < len(A) and j < len(A):
            if A[i] % 2 == 0:
                i += 2
            elif A[j] % 2 == 1:
                j += 2
            elif A[i] % 2 == 1 and A[j] % 2 == 0:
                A[i], A[j] = A[j], A[i]
        return A

执行结果:

通过

显示详情

执行用时:196 ms, 在所有 Python 提交中击败了86.04%的用户

内存消耗:14.5 MB, 在所有 Python 提交中击败了25.00%的用户

最后

以上就是缥缈朋友为你收集整理的【Python】【难度:简单】Leetcode 922. 按奇偶排序数组 II【完】的全部内容,希望文章能够帮你解决【Python】【难度:简单】Leetcode 922. 按奇偶排序数组 II【完】所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(43)

评论列表共有 0 条评论

立即
投稿
返回
顶部