题目描述
编写一个程序,将输入字符串中的字符按如下规则排序(一个测试用例可能包含多组数据,请注意处理)。
规则 1 :英文字母从 A 到 Z 排列,不区分大小写。
如,输入: Type 输出: epTy
规则 2 :同一个英文字母的大小写同时存在时,按照输入顺序排列。
如,输入: BabA 输出: aABb
规则 3 :非英文字母的其它字符保持原来的位置。
如,输入: By?e 输出: Be?y
样例:
输入:
A Famous Saying: Much Ado About Nothing(2012/8).
输出:
A aaAAbc dFgghh : iimM nNn oooos Sttuuuy (2012/8).
输入描述:
输出描述:
示例1
输入
复制
A Famous Saying: Much Ado About Nothing (2012/8).
输出
复制
A aaAAbc dFgghh: iimM nNn oooos Sttuuuy (2012/8).
#include<stdio.h>
#include<ctype.h>//判断是不是字母
#include<string.h>
int main(){
char a[1000];
char b[1000];
int count[26];
int index;char temp;
while(gets(a)){
memset(count,0,sizeof(int)*26);//初始化
for(int i=0;a[i]!='\0';i++){
if(isalpha(a[i])){//判断是不是字母
temp=tolower(a[i]);//变为小写字母
index=temp-'a';
b[count[index]*26+index]=a[i];
count[index]++;
}
}
int j=0;
for(int i=0;i<26;i++){
for(int k=0;k<count[i];k++){
if(isalpha(a[j]))
a[j]=b[i+k*26];
else
k--;
j++;
}
}
printf("%s\n",a);
}
}