LeetCode 905. 按奇偶排序数组

题目描述

给定一个非负整数数组 A,返回一个由 A 的所有偶数元素组成的数组,后面跟 A 的所有奇数元素。

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

示例:

输入:[3,1,2,4]
输出:[2,4,3,1]
输出 [4,2,3,1],[2,4,1,3] 和 [4,2,1,3] 也会被接受。

提示:

1 <= A.length <= 5000
0 <= A[i] <= 5000

思路

  1. 额外增加一个 vector B,第一次循环将所有偶数放进 B 中,第二次循环将所有奇数放进 B 中。
class Solution {
public:
    vector<int> sortArrayByParity(vector<int>& A) {
        int length = A.size();
        vector<int> B(length);
        int i, j = 0;
        if(length == 0)
            return B;
        for(i = 0; i < length; i++)
        {
            if(A[i] % 2 == 0)
                B[j++] = A[i];
        }
        for(i = 0; i < length; i++)
        {
            if(A[i] % 2 == 1)
                B[j++] = A[i];
        }
        return B;
    }
};

2.一次循环,偶数放入头部,奇数放入尾部。

class Solution {
public:
    vector<int> sortArrayByParity(vector<int>& A) {
        int length = A.size();
        vector<int> B(length);
        int i, j = 0, m = length-1;
        if(length == 0)
            return B;
        for(i = 0; i < length; i++)
        {
            if(A[i] % 2 == 0)
                B[j++] = A[i];
            else
                B[m--] = A[i];
        }
        return B;
    }
};
  1. 前面循环发现是奇数,后面循环是偶数,交换
class Solution {
public:
    vector<int> sortArrayByParity(vector<int>& A) {
        int length = A.size();
        int i = 0, j = length-1;
        if(length == 0)
            return A;
        while(i < j)
        {
            while(A[i] % 2 == 0)
                i++;
            while(A[j] % 2 == 1)
                j--;
            if(i < j)
            {
                int temp = A[i];
                A[i] = A[j];
                A[j] = temp;
            }
                
        }
        return A;
    }
};
全部评论

相关推荐

不困不吃饭:个人作品放链接里边。另外字太多了,无法删减的话可以用加粗注明关键的地方(不要全加粗了,只标记关键点)。个人能力往下边放,学历放最上边,如果说你觉得学校不好怕被刷掉的话,那就把实习经历放上边。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务