【剑指Offer-Java】调整数组顺序使奇数位于偶数前面

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

题目描述

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

思路

最直观的方法:先统计出奇数的个数,然后建个新数组,遍历原数组,根据奇数偶数判断在新数组中存放的位置:
若是奇数:直接从新数组第一个位置开始放
若是偶数:让出奇数的位置(对应得到的奇数个数),再逐个放进去

最后把新数组的元素再赋值给原数组,即完成题目要求

实现

public void reOrderArray(int [] array) {
        /*先遍历数组统计出奇数个数
        新建一个和array等长的数组,
        遍历array,遇到奇数就从头开始放进新数组‘遇到偶数就从奇数总数下一个位置开始放
        */
        int oddNum=0;
        int oddStart=0;  //奇数开始的位置(初始就是第一个)
        for(int i=0;i<array.length;i++){
            if(array[i]%2==1){
                oddNum++;
            }
        }
        //新建一个等长数组来存放想要的序列
        int[] newArray=new int[array.length];
        //遍历,判断放进新数组的位置
        for(int i=0;i<array.length;i++){
            if(array[i]%2==1){                 //若是奇数,直接从第一个位置开始向后放
                newArray[oddStart++]=array[i];
            }
            else{                              //若是偶数,让出奇数的位置,从奇数后面开始放
                newArray[oddNum++]=array[i];
            }
        }
        
        //最后再把新数组的元素赋给原数组
        for(int i=0;i<newArray.length;i++){
            array[i]=newArray[i];
        }   
    }

时间复杂度和空间复杂度都是O(n),相比网友们说的排序算法要快很多,算是牺牲空间来换取时间吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值