剑指offer十三之调整数组顺序使奇数位于偶数前面

Posted AI菌

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer十三之调整数组顺序使奇数位于偶数前面相关的知识,希望对你有一定的参考价值。

一、题目

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

二、思路

       此题可以用类似冒泡排序的算法来解答。遍历数组,当相邻两个数,前面的数是偶数,后面的数是奇数时,交换两个数。第一轮遍历下来,数组最后面的一个偶数就排好了,接着进行第二轮第三轮,直到所有偶数都排到奇数后面为止。

三、代码

技术分享
public class Solution {
    public void reOrderArray(int [] array) {
         int temp = 0;
        for (int i = 0; i < array.length - 1; i++) {
            for (int j = 0; j < array.length - 1-i; j++) {
                if ((array[j] % 2 == 0) && (array[j + 1] % 2) != 0) { //前偶后奇则交换
                    temp = array[j];
                    array[j] = array[j + 1];
                    array[j + 1] = temp;
                }
            }
        }
    }
}
View Code

-------------------------------------------------------------------------------------------------------------

参考链接:https://www.nowcoder.com/profile/369342/codeBookDetail?submissionId=1523408

 

以上是关于剑指offer十三之调整数组顺序使奇数位于偶数前面的主要内容,如果未能解决你的问题,请参考以下文章

剑指offer:调整数组顺序使奇数位于偶数前面

《剑指Offer》题目:调整数组顺序使奇数位于偶数前面

剑指offer 13.调整数组顺序使奇数位于偶数前面

剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 的详细题解

《剑指Offer——调整数组顺序使奇数位于偶数前面》代码

剑指offer调整数组顺序使奇数位于偶数前面