• 面试题:调整数组顺序


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

    方法1:两次遍历填充

    public class Solution {
        public void reOrderArray(int [] array) {
            int length=array.length;
            int[] result = new int[length];
            int index = 0;
            for(int i=0;i<array.length;i++){
                if(array[i]%2 == 1){
                    result[index++]=array[i];
                }
            }
            for(int i=0;i<array.length;i++){
                if(array[i]%2 == 0){
                    result[index++]=array[i];
                }
            }
        }
    }

    方法2:借鉴插入排序

    public class Solution {
        public void reOrderArray(int [] array) {
            int index = 0;
            for(int i=0;i<array.length;i++){
                if(array[i]%2 == 1){
                    for(int j=i;j>index;j--){
                        int temp=array[j];
                        array[j]=array[j-1];
                        array[j-1]=temp;
                    }
                    index++;
                }
            }
        }
    }

    方法3:借鉴快速排序

    public class Solution {
        public static void reOrderArray(int [] array) {
            int start = 0;
            int end = array.length - 1;
            while(start<end){
                if(array[start]%2==1){
                    start++;
                }
                if(array[end]%2==0){
                    end--;
                }
                for(int i=start;i<end;i++){
                    if(array[i]%2==0&&array[i+1]%2==1){
                        int temp = array[i];
                        array[i] = array[i+1];
                        array[i+1] = temp;
                    }
                }
            }
        }
    }

    方法4:借鉴冒泡排序

    public class Solution {
        public static void reOrderArray(int [] array) {
            if(array.length == 0){
                return;
            }
            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==1){
                        int temp = array[j];
                        array[j] = array[j+1];
                        array[j+1] = temp;
                    }
                }
            }
        }
    }

    类似题目:数组正负值排序,把负值放在左边正值放在右边(相对无序)

    方法1:两次遍历填充

    方法2:借鉴插入排序

    public class Solution {
        public static void reOrderArray(int [] array) {
            int index = 0;
            for(int i=0;i<array.length;i++){
                if(array[i] < 0){
                    for(int j=i;j>index;j--){
                        int temp = array[j];
                        array[j] = array[j-1];
                        array[j-1] = temp;
                    }
                    index++;
                }
            }
        }
    }

    方法3:借鉴快速排序

    public class Solution {
        public static void reOrderArray(int [] array) {
            int start = 0;
            int end = array.length - 1;
            while(start != end){
                while(start<end && array[end]<0){
                    start++;
                }
                while(start<end && array[end]>=0){
                    end--;
                }
                if(start<end){
                    int temp = array[start];
                    array[start] = array[end];
                    array[end] = temp;
                }
            }
        }
    }
  • 相关阅读:
    【luogu4719】动态DP模板 [动态DP]
    【2019.9.22】
    [JSOI2010]连通数[tarjan缩点]
    【2019.9.16】Za
    【2019.9.18】Za
    [USACO14OPEN]GPS的决斗Dueling GPS's [最短路]
    【CF891C】Envy [最小生成树]
    【2019.9.17】Za
    【2019.9.17】
    【luogu3403】跳楼机 [同余最短路]
  • 原文地址:https://www.cnblogs.com/Aaron12/p/9504683.html
Copyright © 2020-2023  润新知