ASCII码排序
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 342040 Accepted Submission(s): 132515
Problem Description
输入三个字符后,按各字符的ASCII码从小到大的顺序输出这三个字符。
Input
输入数据有多组,每组占一行,有三个字符组成,之间无空格。
Output
对于每组输入数据,输出一行,字符中间用一个空格分开。
Sample Input
qwe
asd
zxc
Sample Output
e q w
a d s
c x z
#include<stdio.h>
int main() {
char a[3],t;
while (scanf("%c%c%c", &a[0], &a[1], &a[2]) != EOF) {
getchar();
int i,j;
for (i = 0; i <= 1; i++) {
for (j = 2; j > i; j--) {
if (a[j] < a[j - 1]) {
t = a[j]; a[j] = a[j - 1]; a[j - 1] = t;
}
}
}
printf("%c %c %c\n", a[0], a[1], a[2]);
}
return 0;
}
注意:
while(scanf(...)!=EOF){...} //含有多组测试数据,读取到文件末尾
getchar(); //读取回车
思想:
- 冒泡排序