解题思路:

注意事项:

参考代码:

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

// 定义一个函数place,用于对输入的字符串按ASCII码从小到大进行冒泡排序
void place(char *ch) {
    int i, j;
    int len = strlen(ch);
    char t;

    // 外层循环,用于控制排序轮数,每轮将一个字符放到正确的位置
    for (i = 0; i < len - 1; i++) {
        // 内层循环,用于比较相邻字符并进行交换
        for (j = 0; j < len - 1 - i; j++) {
            // 如果当前字符大于下一个字符,交换它们
            if (ch[j] > ch[j + 1]) {
                t = ch[j];
                ch[j] = ch[j + 1];
                ch[j + 1] = t;
            }
        }
    }
    // 输出排序后的字符串,并添加换行符
    printf("%s\n", ch);
}

int main() {
    int m, x;
    scanf("%d", &m);
    char ch1[21];

    // 循环读取输入,进行排序,并输出排序后的字符串
    for (x = 0; x < m; x++) {
        scanf("%s", ch1);
        place(ch1); // 调用place函数进行排序
    }

    return 0;
}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论