问题描述: Lily上课时使用字母数字图片教小朋友们学习英语单词,每次都需要把这些图片按照大小(ASCII码值从小到大)排列收好。请大家给Lily帮忙,通过C语言解决。
知识点:字符串
输入:Lily使用的图片包括"A"到"Z"、"a"到"z"、"0"到"9"。输入字母或数字个数不超过1024。
输出:Lily的所有图片按照从小到大的顺序输出
样例输入:Ihave1nose2hands10fingers
样例输出:0112Iaadeeefghhinnnorsssv
问题分析:将一个字符串中的字符按照ASCII码值从小到大重新排序
代码:
#include <stdio.h>
#include <stdlib.h>
int compare(const void *a, const void *b);//快速排序比较函数
int main()
{
char sInput[1024];
gets(sInput);
int len = 0;
while(sInput[len] != '\0')
{
len ++;
}
qsort(sInput, len, sizeof(char), compare);
puts(sInput);
return 0;
}
int compare(const void *a, const void *b)
{
return *(char *)a - *(char *)b;//根据ascii码值来排序,返回小于0的值表示a比较小,大于0表示a比较大
}