题解 | #字符串排序#

字符串排序

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

思路

  1. 得到输入数据
  2. 将字符串中的字符不分大小写按顺序存到新数组
  3. 输出结果,原字符串中为大小写字母的用新字符串替换

Answer

#include<stdio.h>
#include<string.h>

int main() {
    char str[1001] = {0};
    int index = 0;
    gets(str);
    int len = strlen(str);
    char str_ch[len];
    for (char j = 'A'; j <= 'Z'; j++) {
        for (int i = 0; i < len; i++) {
            if ((str[i] == j)
                    || ( (str[i] - 32 == j)
                         && str[i] >= 'a' && str[i] <= 'z')) {
                str_ch[index++] = str[i];
            }
        }
    }
    index = 0;
    for (int i = 0; i < len; i++) {
        if ((str[i] >= 'a' && str[i] <= 'z') || (str[i] >= 'A' && str[i] <= 'Z')) {
            str[i] = str_ch[index++];
        }
        printf("%c", str[i]);
    }
    return 0;
}
全部评论

相关推荐

勇敢的90后想交流:我愿意付费上班,楼主你就安心字节待着吧,我是真的喜欢上班
点赞 评论 收藏
分享
阿武同学:硕士放本科前面,个人简介职业技能不要写这么多,项目经历简短的文字分1/2/3,突出重点,共青团员可以不用写
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
昨天 14:48
点赞 评论 收藏
分享
评论
7
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务