题目描述

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

思路

思路一:

首先统计奇数的个数,然后拷贝一个数组,设置两个指针,奇数指针从0开始,偶数指针从奇数个数的末尾开始遍历,填充到原数组

时间复杂度(O(n)) 空间复杂度(O(n))

思路二:

由于要保证稳定即证奇数和奇数,偶数和偶数之间的相对位置不变,使用插入排序思想

时间复杂度(O(n^2)) 空间复杂度(O(1))

代码实现

package Array;
/**
 * 调整数组顺序使奇数位于偶数前面
 * 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
 */
public class Solution48 {
    public static void main(String[] args) {
        Solution48 solution48 = new Solution48();
        int[] array = {1, 2, 3, 4, 5, 6};
        solution48.reOrderArray_2(array);
        for (int i :
                array) {
            System.out.print(i + " ");
        }
    }
    /**
     * 由于要保证稳定即证奇数和奇数,偶数和偶数之间的相对位置不变,使用插入排序思想
     * 复杂度:O(N2) + O(1)
     *
     * @param array
     */
    public void reOrderArray_2(int[] array) {
        if (array.length == 0 || array == null)
            return;
        int n = array.length;
        for (int i = 0; i < n; i++) {
            if (array[i] % 2 == 0) {
                int nextOddIdx = i + 1;
                while (nextOddIdx < n && array[nextOddIdx] % 2 == 0) {
                    nextOddIdx++;
                }
                if (nextOddIdx == n) {
                    break;
                }
                int nextOddVal = array[nextOddIdx];
                for (int j = nextOddIdx; j > i; j--) {
                    array[j] = array[j - 1];
                }
                array[i] = nextOddVal;
            }
        }
    }
    /**
     * 新建一个数组
     * 复杂度:O(N) + O(N)
     *
     * @param array
     */
    public void reOrderArray(int[] array) {
        int oddCnt = 0;
        for (int val : array) {
            if (val % 2 == 1) {
                oddCnt++;
            }
        }
        int[] copy = array.clone();
        int i = 0, j = oddCnt;
        for (int num : copy) {
            if (num % 2 == 1) {
                array[i++] = num;
            } else {
                array[j++] = num;
            }
        }
    }
}