# 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;
    }
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
  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;
    }
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24