-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathReorderArray.cpp
More file actions
35 lines (27 loc) · 965 Bytes
/
ReorderArray.cpp
File metadata and controls
35 lines (27 loc) · 965 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// 面试题21:调整数组顺序使奇数位于偶数前面
// 题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有
// 奇数位于数组的前半部分,所有偶数位于数组的后半部分。
#include<vector>
using namespace std;
class Solution {
public:
void reOrderArray(vector<int> &array) {
auto begin = array.begin();
auto end = array.end();
while (begin < end)
{
// 向后移动begin,直到它指向偶数
while (begin < end && (*begin & 0x1) != 0)
begin ++;
// 向前移动end,直到它指向奇数
while (begin < end && (*end & 0x1) == 0)
end --;
if(begin < end)
{
int temp = *begin;
*begin = *end;
*end = temp;
}
}
}
};