1. 程式人生 > >JavaStudy——0067:整數奇偶排序

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(); } }