鱼C论坛

 找回密码
 立即注册
查看: 1824|回复: 2

[已解决]【c语言数组】字符串排序题求助

[复制链接]
发表于 2023-4-24 10:12:27 | 显示全部楼层 |阅读模式

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

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

x
先输入你要输入的字符串的个数。然后换行输入该组字符串。每个字符串以回车结束,每个字符串少于一百个字符。
如果在输入过程中输入的一个字符串为“stop”,也结束输入。
然后将这输入的该组字符串按每个字符串的长度,由小到大排序,按排序结果输出字符串。

样例输入
4
faeruhyytrjh tjytj
hsrthts   hjnshtgfhs
stop
3
htrskbns
bsartanjsf tyjndyt
nsr jj jtey

样例输出
faeruhyytrjh tjytj
hsrthts   hjnshtgfhs
htrskbns
nsr jj jtey
bsartanjsf tyjndyt

  1. #include<stdio.h>
  2. #include<string.h>
  3. int main()
  4. {
  5.         char s[100][101],b[1];
  6.         int i,j,n;
  7.       
  8.         while(scanf("%d",&n)!=EOF)
  9.         {
  10.             gets(b);
  11.             for(i=0;i<n;i++){
  12.                 int p[101];
  13.                 gets(p);
  14.                 if(strcmp(p,"stop")==0){
  15.                     n=i;
  16.                     break;
  17.                 }
  18.                 else strcpy(s,p);
  19.             }
  20.             
  21.             for(i=0;i<n-1;i++){
  22.                 for(j=i+1;j<n;j++){
  23.                     if(strlen(s)>strlen(s[j])){
  24.                         char t[101]={'\0'};
  25.                         strcpy(t,s);
  26.                         strcpy(s,s[j]);
  27.                         strcpy(s[j],t);
  28.                     }
  29.                 }
  30.             }
  31.             for(i=0;i<n;i++) printf("%s\n",s);
  32.             
  33.         }
  34.         return 0;
  35. }
复制代码


两个测试点有一个答案错误,实在找不出问题在哪了 谢谢各位大佬
最佳答案
2023-5-20 11:12:45
在程序中,定义了 s 和 b 数组。其中,s 数组用于保存输入的字符串,b 数组用于读取输入中多余的字符。但是在 gets 函数中,传入的实参是 p 数组,这会导致输入数据时出现问题。

此外,在对字符串进行排序时,使用了错误的数组名称和赋值语句。应该是将 s[i] 和 s[j] 进行比较,并将其交换位置,代码如下:

  1. for(i=0;i<n-1;i++){
  2.     for(j=i+1;j<n;j++){
  3.         if(strlen(s[i])>strlen(s[j])){
  4.             char t[101]={'\0'};
  5.             strcpy(t,s[i]);
  6.             strcpy(s[i],s[j]);
  7.             strcpy(s[j],t);
  8.         }
  9.     }
  10. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-4-24 10:16:03 | 显示全部楼层
本帖最后由 isdkz 于 2023-4-24 10:54 编辑

[b]你好!我发现了你代码中的一些问题。我会对代码进行修改并解释修改的原因。

首先,你需要在每次输入一组字符串时将索引重置为零。在代码中,你应该使用`s[i]`,而不是`s`。另外,`strcpy(s,p)`应该改为`strcpy(s[i],p)`,因为你要复制到`i`行。

修正后的代码如下:

  1. #include<stdio.h>
  2. #include<string.h>
  3. int main()
  4. {
  5.     char s[100][101], b[1];
  6.     int i, j, n;

  7.     while (scanf("%d", &n) != EOF)
  8.     {
  9.         gets(b);
  10.         for (i = 0; i < n; i++)
  11.         {
  12.             char p[101];
  13.             gets(p);
  14.             if (strcmp(p, "stop") == 0)
  15.             {
  16.                 n = i;
  17.                 break;
  18.             }
  19.             else strcpy(s[i], p);
  20.         }

  21.         for (i = 0; i < n - 1; i++)
  22.         {
  23.             for (j = i + 1; j < n; j++)
  24.             {
  25.                 if (strlen(s[i]) > strlen(s[j]))
  26.                 {
  27.                     char t[101] = {'\0'};
  28.                     strcpy(t, s[i]);
  29.                     strcpy(s[i], s[j]);
  30.                     strcpy(s[j], t);
  31.                 }
  32.             }
  33.         }
  34.         for (i = 0; i < n; i++) printf("%s\n", s[i]);
  35.     }
  36.     return 0;
  37. }
复制代码


这个修正后的代码应该可以解决你遇到的问题。如果还有其他问题,请随时告诉我![/b]
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-20 11:12:45 | 显示全部楼层    本楼为最佳答案   
在程序中,定义了 s 和 b 数组。其中,s 数组用于保存输入的字符串,b 数组用于读取输入中多余的字符。但是在 gets 函数中,传入的实参是 p 数组,这会导致输入数据时出现问题。

此外,在对字符串进行排序时,使用了错误的数组名称和赋值语句。应该是将 s[i] 和 s[j] 进行比较,并将其交换位置,代码如下:

  1. for(i=0;i<n-1;i++){
  2.     for(j=i+1;j<n;j++){
  3.         if(strlen(s[i])>strlen(s[j])){
  4.             char t[101]={'\0'};
  5.             strcpy(t,s[i]);
  6.             strcpy(s[i],s[j]);
  7.             strcpy(s[j],t);
  8.         }
  9.     }
  10. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-22 16:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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