# 调整数组顺序使奇数位于偶数前面

# 题目描述

输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。

# 思路

类似于冒泡排序的思路,如果当前数是偶数,并且下一个数是奇数,那就把这两个数位置交换。

# 代码

function reOrderArray(array) {
  for (let i = 0; i < array.length; i++) {
    for (let j = 0; j < array.length - i - 1; j++) {
      if (array[j] % 2 === 0 && array[j + 1] % 2 === 1) {
        // 前偶后奇就交换
        [array[j + 1], array[j]] = [array[j], array[j + 1]];
      }
    }
  }
  return array;
}
1
2
3
4
5
6
7
8
9
10
11