奇偶数排序

题目描述

输入10个整数,彼此以空格分隔。重新排序以后输出(也按空格分隔),要求: 1.先输出其中的奇数,并按从大到小排列; 2.然后输出其中的偶数,并按从小到大排列。

输入描述:

任意排序的10个整数(0~100),彼此以空格分隔。

输出描述:

可能有多组测试数据,对于每组数据,按照要求排序后输出,由空格分隔。

  1. 测试数据可能有很多组,请使用while(cin>>a[0]>>a[1]>>...>>a[9])类似的做法来实现;
  2. 输入数据随机,有可能相等。

分析:

直接给数组排序,第一轮正向输出奇数,第二次反向输出偶数

#include <iostream>

using namespace std;

int main(){
    int a[10];
    while(cin >> a[0]){
        for(int i = 1; i < 10; i++)
            cin >> a[i];
        for(int i = 0; i < 10; i++)
            for(int j = 0; j < 10 - i - 1; j++){
                if(a[j] < a[j + 1]) {
                    int temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                }
            }
        for(int i = 0; i < 10; i++){
            if(a[i] % 2 == 1) cout << a[i] << " ";
        }
        for(int i = 9; i >= 0; i--){
            if(a[i] % 2 == 0) cout << a[i] << " ";
        }
    }
    cout << endl;
    return 0;
}

猜你喜欢

转载自www.cnblogs.com/zhuobo/p/10204735.html