鱼C论坛

 找回密码
 立即注册
查看: 1226|回复: 6

[已解决]兄弟们姐妹们啊,就这一个小问题,当局者迷了,大家帮看看

[复制链接]
发表于 2022-2-12 19:52:25 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 kjj2931 于 2022-2-12 19:55 编辑
  1. void compare(char *c[],int n);
  2. #include <stdio.h>
  3. #include <string.h>
  4. int main()
  5. {
  6.         int q = 0;
  7.         char *c[] = {"Follow me","BASIC","Great Wall","FORTRAN","Computer design"};
  8.         printf("这是按照要求排序后的字符串!\n\n");
  9.         printf("%s\n\n",c[0]);//如果要输出一个字符串,使用%s,那么后面只能是地址c[0]
  10.         printf("%c\n",*c[0]);//如果需要输出字符,那么需要加个星号,指向它输出!
  11.         for(q = 0;q<5;q++)
  12.         {
  13.                 compare(c+q,q);
  14.                 printf("%s",*(c+q));
  15.         }
  16.        
  17. }
  18. void compare(char *c[],int n)
  19. {
  20.         int i = 0,j = 0;
  21.         int max;
  22.         int sum = 0;
  23.         if(*c[n]>=65&&(*c[n]+1)>=97)
  24.         {
  25.                 sum = strlen(c[n]);
  26.                 *c[n] = *c[n] + 32;
  27.                 for(i = 0;i<sum;i++)
  28.                 {
  29.                         if(*c[i]==' ')
  30.                         {
  31.                                 continue;
  32.                         }
  33.                         for(j = 1;j<sum;j++)
  34.                         {
  35.                                 if(*c[j] == ' ')
  36.                                 {
  37.                                         continue;
  38.                                 }
  39.                                 else if(*c[i]>*c[j])
  40.                                 {
  41.                                         max = *c[i];
  42.                                         *c[i] = *c[j];
  43.                                         *c[j] = max;       
  44.                                        
  45.                                 }       
  46.                         }       
  47.                 }
  48.         }
  49.         else
  50.         {
  51.                 sum = strlen(c[n]);
  52.                 for(i = 0;i<sum;i++)
  53.                 {
  54.                         for(j = 1;j<sum;j++)
  55.                         {
  56.                                 if(*c[i]>*c[j])
  57.                                 {
  58.                                         max = *c[i];
  59.                                         *c[i] = *c[j];
  60.                                         *c[j] = max;       
  61.                                        
  62.                                 }       
  63.                         }       
  64.                 }
  65.         }
  66. }
复制代码


出错位置一直在第13行,一编译就显示[Warning] passing argument 1 of 'compare' from incompatible pointer type    还有expected 'char **' but argument is of type 'char *'
最佳答案
2022-2-12 20:02:40
本帖最后由 jhq999 于 2022-2-12 20:04 编辑

字符串常量不允许修改
  1. void compare(char *c[],int n);
  2. #include <stdio.h>
  3. #include <string.h>
  4. int main()
  5. {
  6.         int q = 0;
  7.         char *c[] = {"Follow me","BASIC","Great Wall","FORTRAN","Computer design"};/////////////////////////这里面都是字符串常量
  8.         printf("这是按照要求排序后的字符串!\n\n");
  9.         printf("%s\n\n",c[0]);//如果要输出一个字符串,使用%s,那么后面只能是地址c[0]
  10.         printf("%c\n",*c[0]);//如果需要输出字符,那么需要加个星号,指向它输出!
  11.         for(q = 0;q<5;q++)
  12.         {
  13.                 compare(c+q,q);
  14.                 printf("%s",*(c+q));
  15.         }
  16.         
  17. }
  18. void compare(char *c[],int n)
  19. {
  20.         int i = 0,j = 0;
  21.         int max;
  22.         int sum = 0;
  23.         if(*c[n]>=65&&(*c[n]+1)>=97)
  24.         {
  25.                 sum = strlen(c[n]);
  26.                 *c[n] = *c[n] + 32;
  27.                 for(i = 0;i<sum;i++)
  28.                 {
  29.                         if(*c[i]==' ')
  30.                         {
  31.                                 continue;
  32.                         }
  33.                         for(j = 1;j<sum;j++)
  34.                         {
  35.                                 if(*c[j] == ' ')
  36.                                 {
  37.                                         continue;
  38.                                 }
  39.                                 else if(*c[i]>*c[j])
  40.                                 {
  41.                                         max = *c[i];
  42.                                         *c[i] = *c[j];
  43.                                         *c[j] = max;        
  44.                                        
  45.                                 }        
  46.                         }        
  47.                 }
  48.         }
  49.         else
  50.         {
  51.                 sum = strlen(c[n]);
  52.                 for(i = 0;i<sum;i++)
  53.                 {
  54.                         for(j = 1;j<sum;j++)
  55.                         {
  56.                                 if(*c[i]>*c[j])
  57.                                 {
  58.                                         max = *c[i];
  59.                                         *c[i] = *c[j];///////////////////字符串常量不可改变
  60.                                         *c[j] = max;        
  61.                                        
  62.                                 }        
  63.                         }        
  64.                 }
  65.         }
  66. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-2-12 19:54:58 | 显示全部楼层
真的迷在其中了,感觉很简单,就是找不出为啥一直提示那里错了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-12 19:56:12 | 显示全部楼层
麻了
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-2-12 20:02:40 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jhq999 于 2022-2-12 20:04 编辑

字符串常量不允许修改
  1. void compare(char *c[],int n);
  2. #include <stdio.h>
  3. #include <string.h>
  4. int main()
  5. {
  6.         int q = 0;
  7.         char *c[] = {"Follow me","BASIC","Great Wall","FORTRAN","Computer design"};/////////////////////////这里面都是字符串常量
  8.         printf("这是按照要求排序后的字符串!\n\n");
  9.         printf("%s\n\n",c[0]);//如果要输出一个字符串,使用%s,那么后面只能是地址c[0]
  10.         printf("%c\n",*c[0]);//如果需要输出字符,那么需要加个星号,指向它输出!
  11.         for(q = 0;q<5;q++)
  12.         {
  13.                 compare(c+q,q);
  14.                 printf("%s",*(c+q));
  15.         }
  16.         
  17. }
  18. void compare(char *c[],int n)
  19. {
  20.         int i = 0,j = 0;
  21.         int max;
  22.         int sum = 0;
  23.         if(*c[n]>=65&&(*c[n]+1)>=97)
  24.         {
  25.                 sum = strlen(c[n]);
  26.                 *c[n] = *c[n] + 32;
  27.                 for(i = 0;i<sum;i++)
  28.                 {
  29.                         if(*c[i]==' ')
  30.                         {
  31.                                 continue;
  32.                         }
  33.                         for(j = 1;j<sum;j++)
  34.                         {
  35.                                 if(*c[j] == ' ')
  36.                                 {
  37.                                         continue;
  38.                                 }
  39.                                 else if(*c[i]>*c[j])
  40.                                 {
  41.                                         max = *c[i];
  42.                                         *c[i] = *c[j];
  43.                                         *c[j] = max;        
  44.                                        
  45.                                 }        
  46.                         }        
  47.                 }
  48.         }
  49.         else
  50.         {
  51.                 sum = strlen(c[n]);
  52.                 for(i = 0;i<sum;i++)
  53.                 {
  54.                         for(j = 1;j<sum;j++)
  55.                         {
  56.                                 if(*c[i]>*c[j])
  57.                                 {
  58.                                         max = *c[i];
  59.                                         *c[i] = *c[j];///////////////////字符串常量不可改变
  60.                                         *c[j] = max;        
  61.                                        
  62.                                 }        
  63.                         }        
  64.                 }
  65.         }
  66. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-2-13 15:05:53 | 显示全部楼层
本帖最后由 傻眼貓咪 于 2022-2-13 15:13 编辑

不知道是不是你要的:
  1. #include <stdio.h>
  2. #include <ctype.h>

  3. void change(char[], size_t);
  4. void swap(char*, char*);

  5. int main() {
  6.         char str[][20] = { "Follow me","BASIC","Great Wall","FORTRAN","Computer design" }; // <----- 注意这里 -----

  7.         size_t
  8.                 N = sizeof(str) / sizeof(char[20]), // 数组长度
  9.                 n; // 字符串长度

  10.         for (int i = 0; i < (int)N; i++) {
  11.                 n = sizeof(str[i]) / sizeof(char); // 字符串长度
  12.                 printf("%s -> ", str[i]);
  13.                 change(*(str + i), n); // 改变字符串字符循序
  14.                 printf("%s\n", str[i]);
  15.         }
  16.         return 0;
  17. }

  18. /* 改变字符串字符循序 */
  19. void change(char str[], size_t n) {
  20.         char a, b;
  21.         for (size_t i = 0; i < n - 1; i++) {
  22.                 if (isalpha(str[i])) {
  23.                         if (str[i] >= 'A' && str[i] <= 'Z') a = str[i] + ('a' - 'A');
  24.                         else a = str[i];
  25.                 }
  26.                 else continue;
  27.                 for (size_t j = i + 1; j < n; j++) {
  28.                         if (isalpha(str[j])) {
  29.                                 if (str[j] >= 'A' && str[j] <= 'Z') b = str[j] + ('a' - 'A');
  30.                                 else b = str[j];
  31.                                 if (a > b) swap(&(str[i]), &(str[j]));
  32.                         }
  33.                         else continue;
  34.                 }
  35.         }
  36. }

  37. /* 字符交换位置 */
  38. void swap(char* p, char* q) {
  39.         char c = *p;
  40.         *p = *q;
  41.         *q = c;
  42. }
复制代码
  1. Follow me -> eFmllo ow
  2. BASIC -> ABCIS
  3. Great Wall -> allae GrtW
  4. FORTRAN -> ANFORRT
  5. Computer design -> Cngiedes morptu
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-14 07:55:44 | 显示全部楼层
傻眼貓咪 发表于 2022-2-13 15:05
不知道是不是你要的:

谢谢你的帮助,不过,我的意思是不管是大小写字母,都安照26个英文字母顺序来排列。虽然没有符合预期,但是还是很谢谢你,我也发现了我的很多错误。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-14 07:58:07 | 显示全部楼层
jhq999 发表于 2022-2-12 20:02
字符串常量不允许修改

并没有实际解决问题,而且我也明白了直接差的还有一大截,不过我知道了自己那些地方还应该再看看书,谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-25 00:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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