题解 | #字符串排序#

字符串排序

http://www.nowcoder.com/practice/5190a1db6f4f4ddb92fd9c365c944584

非字母的字符串排序后还是在原来的位置,所以先把字母全部提取出来排序,然后非字母的直接打印,
字母按新排序的打印。
#include"stdio.h"
#include"string.h"

char str[1001] = { 0 };
char tmp_str[1000] = { 0 };

int main(void) {
    int len, i, j, t=0, n, num = 0;
    fgets(str, sizeof(str), stdin);
    len = strlen(str);
    while (str[len - 1] == '\n' || str[len - 1] == '\r') {
        len--;
    }

    for(i='A';i<='Z';i++){
        for(j=0;j<len;j++){
            if(str[j] == i || str[j] == i + ('a'-'A')){
                tmp_str[t]=str[j];
//                printf("%c",str[j]);
                t++;
            }
        }
    }
    t=0;
//    printf("%c",'\n');
    for(i=0;i<len;i++){
        if(!((str[i] >= 'A' && str[i] <= 'Z') || (str[i] >= 'a' && str[i] <= 'z'))){
            printf("%c",str[i]); //不是字母直接打印
        }else{
            printf("%c",tmp_str[t]);  //字母按排序后的顺序替换。
            t++;
        }
    }
    return 0;
}


全部评论

相关推荐

一颗宏心:华为HR晚上过了十二点后还给我法消息。
点赞 评论 收藏
分享
10-09 22:05
666 C++
找到工作就狠狠玩CSGO:报联合国演讲,报电子烟设计与制造
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务