总时间限制: 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();
}
}