鱼C论坛

 找回密码
 立即注册
查看: 1293|回复: 5

[已解决]C语言-字符按ASCII降序排序

[复制链接]
发表于 2020-12-13 20:21:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
请问程序哪里出错了吗?
  1. /*编写函数fun,它的功能是:对长度为7个字符的字符串,除首、尾字符外,将其余5个字符按ASCII码将序排列。例如,原来的字符串CEAedca,排序后输出为CedcEAa。*/
  2. #include<stdio.h>
  3. #define M 7
  4. #include<string.h>
  5. char fun(char str){
  6.         int i,j;
  7.         char temp;
  8.         for(i=1;i<6-1;i++){
  9.                 for(j=0;j<6-i-1;j++){
  10.                         if(str[i]<str[j]){
  11.                                 temp=str[j];
  12.                                 str[j]=str[i];
  13.                                 str[i]=temp;
  14.                         }
  15.                 }
  16.         }
  17.         return str;
  18. }
  19. void main()
  20. {
  21.         char str[M];
  22.         scanf("%s",str);
  23.         fun(str);
  24.         printf("\n%s",str);
  25. }
复制代码
最佳答案
2020-12-13 20:52:00
本帖最后由 jackz007 于 2020-12-13 21:00 编辑
  1. char fun(char str){                                // 问题
  2.         int i,j;
  3.         char temp;
  4.         for(i=1;i<6-1;i++){                        // 问题
  5.                 for(j=0;j<6-i-1;j++){              // 问题
  6.                         if(str[i]<str[j]){         
  7.                                 temp=str[j];
  8.                                 str[j]=str[i];
  9.                                 str[i]=temp;
  10.                         }
  11.                 }
  12.         }
  13.         return str;                                // 问题
  14. }
复制代码

        改为
  1. void fun(char str[]){                              // 有修改
  2.         int i , j                             ;
  3.         char temp                             ;
  4.         for(i = 1 ; i < M - 2 ; i ++) {            // 有修改
  5.                 for(j = i + 1; j < M - 1 ; j ++){  // 有修改
  6.                         if(str[i] < str[j]){
  7.                                 temp=str[j]   ;
  8.                                 str[j]=str[i] ;
  9.                                 str[i]=temp   ;
  10.                         }
  11.                 }
  12.         }
  13. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-12-13 20:42:15 | 显示全部楼层
22行,有问题 不能将char[7]转变成char
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-13 20:42:58 | 显示全部楼层
严凯 发表于 2020-12-13 20:42
22行,有问题 不能将char[7]转变成char

看错了,是23行
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-13 20:52:00 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2020-12-13 21:00 编辑
  1. char fun(char str){                                // 问题
  2.         int i,j;
  3.         char temp;
  4.         for(i=1;i<6-1;i++){                        // 问题
  5.                 for(j=0;j<6-i-1;j++){              // 问题
  6.                         if(str[i]<str[j]){         
  7.                                 temp=str[j];
  8.                                 str[j]=str[i];
  9.                                 str[i]=temp;
  10.                         }
  11.                 }
  12.         }
  13.         return str;                                // 问题
  14. }
复制代码

        改为
  1. void fun(char str[]){                              // 有修改
  2.         int i , j                             ;
  3.         char temp                             ;
  4.         for(i = 1 ; i < M - 2 ; i ++) {            // 有修改
  5.                 for(j = i + 1; j < M - 1 ; j ++){  // 有修改
  6.                         if(str[i] < str[j]){
  7.                                 temp=str[j]   ;
  8.                                 str[j]=str[i] ;
  9.                                 str[i]=temp   ;
  10.                         }
  11.                 }
  12.         }
  13. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-12-13 21:04:36 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-13 21:08:48 | 显示全部楼层

非常感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-13 23:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表