描述
编写一个程序,将输入字符串中的字符按如下规则排序。

规则 1 :英文字母从 A 到 Z 排列,不区分大小写。

如,输入: Type 输出: epTy

规则 2 :同一个英文字母的大小写同时存在时,按照输入顺序排列。

如,输入: BabA 输出: aABb

规则 3 :非英文字母的其它字符保持原来的位置。

如,输入: By?e 输出: Be?y

注意有多组测试数据,即输入有多行,每一行单独处理(换行符隔开的表示不同行)

输入描述:
输入字符串
输出描述:
输出字符串
示例1
输入:
A Famous Saying: Much Ado About Nothing (2012/8).
复制
输出:
A aaAAbc dFgghh: iimM nNn oooos Sttuuuy (2012/8).

include <stdio.h>

include <string.h>

void fun(char *str,int len)
{
char buf[26]={0};
char buff[1000]={0};

char *p=str;
int i=0,j=0,z=0;
for(i=0;i<len;i++)
{
    if(p[i]<'A'|| p[i]>'z')
    {
        buff[i]=p[i];
    }
    if(p[i]>'Z'&&p[i]<'a')
        buff[i]=p[i];
}
for(i=0;i<26;i++)
{
    for(j=0;j<len;j++)
    {
        if((p[j]=='a'+i)||(p[j]=='A'+i))
        {
            while(buff[z]!=0)
            {
                z++;
            }
            buff[z]=p[j];
            z++;
        }
    }
}
 printf("%s",buff);

}
int main()
{
char str[1000]={0};
int len;
while(fgets(str,1000,stdin)!=0)
{
len=strlen(str);
// printf("len=%d",len);
fun(str,len);
memset(str,0, sizeof(str));
}

return 0;

}