鱼C论坛

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

[已解决]三数比大小,看不出来问题,为什么运行不对呢

[复制链接]
发表于 2023-11-4 20:26:11 | 显示全部楼层 |阅读模式

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

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

x
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         float a, b, c, max;
  5.         printf("please enter the value of a, b, c\n");
  6.         scanf("%f%f%f", &a, &b, &c);

  7.         if(a > b)
  8.         {
  9.                 max = a;
  10.                 a = b;
  11.                 b = max;
  12.         }
  13.         if(b > c)
  14.         {
  15.                 max = b;
  16.                 b = c;
  17.                 c = max;
  18.         }
  19.         if(a > c)
  20.         {
  21.                 max = a;
  22.                 a = c;
  23.                 c = max;
  24.         }
  25.         printf("从小到大是%5.2f,%5.2f,%5.2f\n", a, b ,c);

  26.         return 0;

  27. }
复制代码
最佳答案
2023-11-4 20:26:23
问题出在你的比较和交换逻辑上。在你的代码中,你只是比较了相邻的两个数,而没有考虑到所有三个数之间的关系。

为了正确地进行三个数的比较和排序,你需要修改你的代码。以下是修改后的代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     float a, b, c, max;

  5.     printf("请输入a、b、c的值:\n");
  6.     scanf("%f %f %f", &a, &b, &c);

  7.     // 比较a和b的大小,如果a大于b,则交换它们的值
  8.     if (a > b) {
  9.         max = a;
  10.         a = b;
  11.         b = max;
  12.     }

  13.     // 再次比较a和c的大小,如果a大于c,则交换它们的值
  14.     if (a > c) {
  15.         max = a;
  16.         a = c;
  17.         c = max;
  18.     }

  19.     // 最后比较b和c的大小,如果b大于c,则交换它们的值
  20.     if (b > c) {
  21.         max = b;
  22.         b = c;
  23.         c = max;
  24.     }

  25.     printf("从小到大排序后的结果为:%5.2f, %5.2f, %5.2f\n", a, b, c);

  26.     return 0;
  27. }
复制代码


这样修改后的代码会正确地比较三个数的大小,并按从小到大的顺序进行排序。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-4 20:26:23 | 显示全部楼层    本楼为最佳答案   
问题出在你的比较和交换逻辑上。在你的代码中,你只是比较了相邻的两个数,而没有考虑到所有三个数之间的关系。

为了正确地进行三个数的比较和排序,你需要修改你的代码。以下是修改后的代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     float a, b, c, max;

  5.     printf("请输入a、b、c的值:\n");
  6.     scanf("%f %f %f", &a, &b, &c);

  7.     // 比较a和b的大小,如果a大于b,则交换它们的值
  8.     if (a > b) {
  9.         max = a;
  10.         a = b;
  11.         b = max;
  12.     }

  13.     // 再次比较a和c的大小,如果a大于c,则交换它们的值
  14.     if (a > c) {
  15.         max = a;
  16.         a = c;
  17.         c = max;
  18.     }

  19.     // 最后比较b和c的大小,如果b大于c,则交换它们的值
  20.     if (b > c) {
  21.         max = b;
  22.         b = c;
  23.         c = max;
  24.     }

  25.     printf("从小到大排序后的结果为:%5.2f, %5.2f, %5.2f\n", a, b, c);

  26.     return 0;
  27. }
复制代码


这样修改后的代码会正确地比较三个数的大小,并按从小到大的顺序进行排序。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-4 20:27:26 | 显示全部楼层
这段代码存在一个问题,即无法正确处理输入三个数相等的情况。

在代码中,通过比较大小来将三个数按从小到大的顺序进行排序。然而,当输入的三个数相等时,代码中的三个条件语句都不会满足,因此不会进行任何交换操作,导致输出结果不是按照预期的从小到大排序。

为了解决这个问题,你可以在最开始的地方添加一个额外的判断条件,判断三个数是否相等,如果相等,则直接输出结果即可。

以下是修改后的代码:
  1. #include <stdio.h>
  2. int main() {
  3.     float a, b, c;
  4.     printf("please enter the value of a, b, c\n");
  5.     scanf("%f%f%f", &a, &b, &c);
  6.     if (a == b && b == c) {
  7.         printf("三个数相等,无需排序,结果为 %5.2f, %5.2f, %5.2f\n", a, b, c);
  8.     } else {
  9.         float max;
  10.         if (a > b) {
  11.             max = a;
  12.             a = b;
  13.             b = max;
  14.         }
  15.         if (b > c) {
  16.             max = b;
  17.             b = c;
  18.             c = max;
  19.         }
  20.         if (a > c) {
  21.             max = a;
  22.             a = c;
  23.             c = max;
  24.         }
  25.         printf("从小到大排序为 %5.2f, %5.2f, %5.2f\n", a, b, c);
  26.     }
  27.     return 0;
  28. }
复制代码

修改后的代码加入了额外的判断条件,当三个数相等时,直接输出结果。这样可以确保在输入三个数相等时也能得到正确的输出。

希望这次的回答能帮助到你,如果还有任何问题,请随时提问。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-4 20:31:45 | 显示全部楼层
sort
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-4 22:13:59 | 显示全部楼层
你的思路就不对啊,这是一个排序,你可以去看一下相关的排序算法,建议先从冒泡排序入手
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-11-5 09:42:32 | 显示全部楼层
yinda_peng 发表于 2023-11-4 22:13
你的思路就不对啊,这是一个排序,你可以去看一下相关的排序算法,建议先从冒泡排序入手

好的,多谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-21 14:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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