# 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
# 思路
- 额外增加一个 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
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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
- 前面循环发现是奇数,后面循环是偶数,交换
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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24