题目描述
给定一个非负整数数组 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
思路
- 额外增加一个 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;
    }
};
  - 前面循环发现是奇数,后面循环是偶数,交换
 
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;
    }
};

京公网安备 11010502036488号