ASCII码排序
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 170835 Accepted Submission(s): 68917
Problem Description
输入三个字符后,按各字符的ASCII码从小到大的顺序输出这三个字符。
Input
输入数据有多组,每组占一行,有三个字符组成,之间无空格。
Output
对于每组输入数据,输出一行,字符中间用一个空格分开。
Sample Input
qwe
asd
zxc
Sample Output
e q w
a d s
c x z
[分析]
没有特别的,既然排序那就一个sort。
[代码]
#include<cstdio>
#include<algorithm>
using namespace std;
int main()
{
char a[4];
while(scanf("%s",a)!=EOF)
{
sort(a,a+3);
printf("%c ",a[0]);
printf("%c ",a[1]);
printf("%c\n",a[2]);
}
return 0;
}
[后记]
既然主角是sort,那么复习一下sort。
#include<cstdio>
#include<algorithm>//需要的头文件
using namespace std;//std也要
int cmp(int &a, int &b)
{
return a > b;
}
int main()
{
int a[] = {2,3,6,45,6,7,8,5,3,6 };
int len=10;
sort(a, a + len);//这样用是默认升序,a是数组,len是长度。
sort(a, a + len, cmp);//这样用是倒序,cmp是自定义函数要自己写(自己试试改变cmp)
for (int i = 0; i < 10; i++)
{
printf("%d ", a[i]);
}
getchar();
}
第一次写博客,感觉很神奇。