JavaStudy——0067:整數奇偶排序
阿新 • • 發佈:2018-11-15
總時間限制: 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();
}
}