JavaStudy——0067:整数奇偶排序

总时间限制: 1000ms 内存限制: 65536kB

描述
给定10个整数的序列,要求对其重新排序。排序要求:
1.奇数在前,偶数在后;
2.奇数按从大到小排序;
3.偶数按从小到大排序。

输入
输入一行,包含10个整数,彼此以一个空格分开,每个整数的范围是大于等于0,小于等于100。
输出
按照要求排序后输出一行,包含排序后的10个整数,数与数之间以一个空格分开。

样例输入

4 7 3 13 11 12 0 47 34 98

样例输出

47 13 11 7 3 0 4 12 34 98

Accepted代码

import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner in=new Scanner(System.in);
        int[] all=new int[10];
        int[] odd=new int[10];
        int[] even=new int[10];
        int numOdd=0,numEven=0,i=0;
        for (i=0;i<10;i++)
            all[i]=in.nextInt();
        for (i=0;i<10;i++)
            if(all[i]%2!=0) {
                odd[numOdd]=all[i];
                numOdd++;
            }
            else {
                even[numEven]=all[i];
                numEven++;
            }
        for (i=0;i<numOdd-1;i++)
            for (int j=i;j<numOdd;j++)
                if(odd[j]>odd[i]) {
                    int tmp=odd[i];
                    odd[i]=odd[j];
                    odd[j]=tmp;
                }
        for (i=0;i<numOdd;i++)
            System.out.print(odd[i]+" ");
        for (i=0;i<numEven-1;i++)
            for (int j=i;j<numEven;j++)
                if(even[j]<even[i]) {
                    int tmp=even[i];
                    even[i]=even[j];
                    even[j]=tmp;
                }
        for (i=0;i<numEven;i++)
            System.out.print(even[i]+" ");
        in.close();
    }
}

猜你喜欢

转载自blog.csdn.net/Alexander1216/article/details/83962674