鱼C论坛

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

[已解决]带你学C带你飞第一季20节动手做问题

[复制链接]
发表于 2023-1-7 16:41:32 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 铭凡 于 2023-1-7 21:12 编辑

小甲鱼老师的问题如下:

2. 每一个好的品牌都有一个耳熟能详的 Slogan(口号)。写一个程序,让用户输入 5 句话,并计算出最长和最短的两句。

要求 A:使用 1 个二维数组存储用户输入的 5 句话。

要求 B:结果打印格式如下图。

010842lxc4hwh1zt05w844.png

然后这个是标准答案:

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

  3. #define NUM 5

  4. int main()
  5. {
  6.         char slogan[NUM][100];
  7.         int i, j, ch, min, max, temp;

  8.         for (i = 0; i < NUM; i++)
  9.         {
  10.                 printf("请输入%d句话:", i+1);
  11.                 for (j = 0; (ch = getchar()) != '\n'; j++)
  12.                 {
  13.                         slogan[i][j] = ch;
  14.                 }
  15.                 slogan[i][j] = '\0';
  16.         }

  17.         min = 0;
  18.         max = min;

  19.         printf("你输入了下边%d句话:\n", NUM);

  20.         // 打印每句口号,同时比较长度
  21.         for (i = 0; i < NUM; i++)
  22.         {
  23.                 printf("%s\n", slogan[i]);
  24.                 temp = strlen(slogan[i]);
  25.                 min = temp < strlen(slogan[min]) ? i : min;
  26.                 max = temp > strlen(slogan[max]) ? i : max;
  27.         }

  28.         printf("其中最长的是:%s\n", slogan[max]);
  29.         printf("其中最短的是:%s\n", slogan[min]);

  30.         return 0;
  31. }
复制代码


这个是我的答案:

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

  3. int main(void)
  4. {
  5.         char str[5][50];
  6.         int i;
  7.         int j;
  8.         for(i = 0; i < 5; i++)
  9.         {
  10.                 printf("请输入第%d句话: ", i + 1);
  11.                 for(j = 0; (str[i][j] = getchar()) != '\n'; j++)
  12.                 {
  13.                         ;
  14.                 }
  15.                 str[i][j] = '\0';
  16.         }
  17.         int length[5];
  18.         for(i = 0; i < 5; i++)
  19.         {
  20.                 length[i] = strlen(str[i]);
  21.         }
  22.        
  23.         int min = 0;
  24.         int max = 0;
  25.        
  26.         for(i = 1; i < 5; i++)
  27.         {
  28.                 if(length[i] < min)
  29.                 {
  30.                         min = i;
  31.                 }
  32.         }
  33.        
  34.         for(i = 1; i < 5; i++)
  35.         {
  36.                 if(length[i] > max)
  37.                 {
  38.                         max = i;
  39.                 }
  40.         }
  41.        
  42.         printf("你输入了下边5句话: \n");
  43.         for(i = 0; i < 5; i++)
  44.         {
  45.                 printf("%s\n", str[i]);
  46.         }
  47.         printf("其中最长的是: %s\n", str[max]);
  48.         printf("其中最短的是: %s\n", str[min]);
  49.        
  50.         return 0;
  51. }
复制代码


提问:请大家注意比较长度这里的逻辑有没有问题

下面附上两张实际操作图

图1

1.png

这个是我用数字测试的

图2

2.png

我按照课后作业的样子输入句子之后,最长的和最短的就交换位置了。。。

求解,谢谢各位大神!
最佳答案
2023-1-7 17:42:41
  1. #include <stdio.h>
  2. #include <string.h>

  3. int main(void)
  4. {
  5.         char str[5][50] = {};
  6.         int i;
  7.         int j;
  8.         for(i = 0; i < 5; i++)
  9.         {
  10.                 printf("请输入第%d句话: ", i + 1);
  11.                 for(j = 0; (str[i][j] = getchar()) != '\n'; j++)
  12.                 {
  13.                         ;
  14.                 }
  15.                 str[i][j] = '\0';
  16.         }
  17.         int length[5];
  18.         for(i = 0; i < 5; i++)
  19.         {
  20.                 length[i] = strlen(str[i]);
  21.         }
  22.       
  23.         int min = 0, minval = 10000;
  24.         int max = 0, maxval = 0;
  25.       
  26.         for(i = 0; i < 5; i++)
  27.         {
  28.                 if(length[i] < minval)
  29.                 {
  30.                         min = i;
  31.                         minval = length[i];
  32.                 }
  33.         }
  34.       
  35.         for(i = 0; i < 5; i++)
  36.         {
  37.                 if(length[i] > maxval)
  38.                 {
  39.                         max = i;
  40.                         maxval = length[i];
  41.                 }
  42.         }
  43.       
  44.         printf("你输入了下边5句话: \n");
  45.         for(i = 0; i < 5; i++)
  46.         {
  47.                 printf("%s\n", str[i]);
  48.         }
  49.         printf("其中最长的是: %s\n", str[max]);
  50.         printf("其中最短的是: %s\n", str[min]);
  51.       
  52.         return 0;
  53. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-1-7 17:42:41 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>
  2. #include <string.h>

  3. int main(void)
  4. {
  5.         char str[5][50] = {};
  6.         int i;
  7.         int j;
  8.         for(i = 0; i < 5; i++)
  9.         {
  10.                 printf("请输入第%d句话: ", i + 1);
  11.                 for(j = 0; (str[i][j] = getchar()) != '\n'; j++)
  12.                 {
  13.                         ;
  14.                 }
  15.                 str[i][j] = '\0';
  16.         }
  17.         int length[5];
  18.         for(i = 0; i < 5; i++)
  19.         {
  20.                 length[i] = strlen(str[i]);
  21.         }
  22.       
  23.         int min = 0, minval = 10000;
  24.         int max = 0, maxval = 0;
  25.       
  26.         for(i = 0; i < 5; i++)
  27.         {
  28.                 if(length[i] < minval)
  29.                 {
  30.                         min = i;
  31.                         minval = length[i];
  32.                 }
  33.         }
  34.       
  35.         for(i = 0; i < 5; i++)
  36.         {
  37.                 if(length[i] > maxval)
  38.                 {
  39.                         max = i;
  40.                         maxval = length[i];
  41.                 }
  42.         }
  43.       
  44.         printf("你输入了下边5句话: \n");
  45.         for(i = 0; i < 5; i++)
  46.         {
  47.                 printf("%s\n", str[i]);
  48.         }
  49.         printf("其中最长的是: %s\n", str[max]);
  50.         printf("其中最短的是: %s\n", str[min]);
  51.       
  52.         return 0;
  53. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-1-7 17:44:01 | 显示全部楼层
因为 min 表示最小长度的编号,不应该出现 length[i] < min 这种,您应该还要记录一下最小长度的值和最大长度的值,比较也就应该用这两个变量来比较
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-1-7 18:36:26 | 显示全部楼层
发帖建议使用代码格式

点评

好的  发表于 2023-1-7 21:08
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-1-7 21:11:36 | 显示全部楼层

这个看明白了,除了max和min这两个用来记录数组名称的变量之外,还要搞两个存储二维数组长度的变量。学到了,谢谢!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-22 22:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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