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

本文介绍了一种在数组中调整数字顺序的算法,确保所有奇数位于数组前半部分,所有偶数位于后半部分。通过使用两个指针分别从数组的开始和结束位置向中间移动,找到奇数和偶数进行交换,最终实现奇偶分离。

题目

输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部。

思路

  1. 两个指针a和b,a指向第一个数字,b指向最后一个数字;
  2. a向后移动直到指向一个偶数,b向前移动直到指向一个奇数,交换两数;
  3. 直到a和b指向同一个数。

代码

    public static void  reorder(int[] array){
        if (array==null){
            return;
        }
        int pre=0;
        int tail=array.length-1;
        int temp=0;
        while (pre<tail){
            while (!isOdd(array[pre]))
                pre++;
            while (isOdd(array[tail]))
                tail--;
            temp=array[pre];
            array[pre]=array[tail];
            array[tail]=temp;
        }
    }
public static boolean isOdd(int n){
        return (n & 1) == 1;
    }

相关问题

上面的如果不改变原来数组中奇数和偶数的先后顺序:

    public static void reOrder1(int[] array){
        if (array==null)
            return;
        int[] result=new int[array.length];
        int count=0;
        for (int anArray : array) {
            if ((anArray & 1) != 0) {
                result[count] = anArray;
                count++;
            }
        }
        for (int anArray : array) {
            if ((anArray & 1) == 0) {
                result[count] = anArray;
                count++;
            }
        }
//        java传递的是副本
//        Java参数,不管是原始类型还是引用类型,传递的都是副本
//        array=result;
        /**
         * 当一个对象实例作为一个参数被传递到方法中时,
         * 参数的值就是该对象的引用一个副本。
         * 指向同一个对象,对象的内容可以在被调用的方法中改变,
         * 但对象的引用(不是引用的副本)是永远不会改变的。
         */
        System.arraycopy(result, 0, array, 0, array.length);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值