NYOJ4 ASCII码排序

刷题,从最水的刷起,刷完为止。每天刷几题也挺有意思。

描述
输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符。
输入
第一行输入一个数N,表示有N组测试数据。后面的N行输入多组数据,每组输入数据都是占一行,有三个字符组成,之间无空格。
输出
对于每组输入数据,输出一行,字符中间用一个空格分开。
样例输入
3
qwe
asd
zxc
样例输出
e q w
a d s
c x z
我的解法:
#include<stdio.h>
#include<stdlib.h>

void swap(char &c1,char &c2)
{
    char tmp=c1;
    c1=c2;
    c2=tmp;
}

int main()
{
    int n;//n组测试数据
    char str[3],tmp;
    scanf("%d",&n);
    while(n--)
    {
        scanf("%s",&str);

        if(str[0]>str[1])swap(str[0],str[1]);
        if(str[0]>str[2])swap(str[0],str[2]);
        if(str[1]>str[2])swap(str[1],str[2]);
        
        printf("%c %c %c\n",str[0],str[1],str[2]);
    }
    //system("PAUSE");
    return 0;
}

网上找到了个写得更规范的。http://www.cnblogs.com/cpoint/archive/2011/04/13/2015340.html

还有个更简单的写法http://acm.nyist.net/JudgeOnline/bestcode.php?pid=4


你可能感兴趣的:(NYOJ4 ASCII码排序)