L178 发表于 2022-10-24 13:31:29

为什么这里max输出的是较小的那个数而不是较大的那个数

本帖最后由 L178 于 2022-10-24 14:10 编辑

为什么这里max输出的是较小的那个数而不是较大的那个数,谢谢
题目给的就是int ,然后让解释为什么输出结果是较小的数

jackz007 发表于 2022-10-24 13:45:36

本帖最后由 jackz007 于 2022-10-24 13:49 编辑

int max(float x , float y)
         函数返回值类型定义错误
float max(float x , float y)
         主函数中 int c 也得相应改成 float c,还有 printf("%d") 也得改,说好的浮点数,怎么悄悄改整型数了???

L178 发表于 2022-10-24 14:09:01

jackz007 发表于 2022-10-24 13:45
函数返回值类型定义错误

         主函数中 int c 也得相应改成 float c,还有 printf("%d") ...

题目给的是int,然后让解释为什么输出结果是较小的那个数的

jackz007 发表于 2022-10-24 14:25:28

本帖最后由 jackz007 于 2022-10-24 14:27 编辑

L178 发表于 2022-10-24 14:09
题目给的是int,然后让解释为什么输出结果是较小的那个数的

#include <stdio.h>

int max(float x , float y)
{
      return (x > y) ? (int) x : (int) y ;
}

int main(void)
{
      float a , b                ;
      int c                      ;
      scanf("%f,%f" , & a , & b) ;
      c = max(a , b)             ;
      printf("%d\n" , c)         ;
}
      编译、运行实况:
D:\\C>g++ -o x x.c

D:\\C>x
9,19
19

D:\\C>
       肯定是因为没有按预期输入,例如,这个代码,要求按 a,b 的格式进行输入,但是,如果输入是 9 19,那么,打印的就是 9。如果你把输入时的大小顺序颠倒一下,比如,输入 19 9 ,看看对结果是否有影响。

L178 发表于 2022-10-24 14:33:29

jackz007 发表于 2022-10-24 14:25
编译、运行实况:

       肯定是因为没有按预期输入,例如,这个代码,要求按 a,b 的格式 ...

是的,但是为什么呢

L178 发表于 2022-10-24 14:34:23

L178 发表于 2022-10-24 14:33
是的,但是为什么呢

输入19 9,输出就是19
输入9 19,输出就是9

jackz007 发表于 2022-10-24 15:01:17

本帖最后由 jackz007 于 2022-10-24 15:03 编辑

L178 发表于 2022-10-24 14:34
输入19 9,输出就是19
输入9 19,输出就是9

      因为,键盘输入语句 scanf("%f,%f" , & a , & b) ,看到 "%f,%f" 中间的逗号了,这种写法要求键盘输入必须要按 a,b 这样输入,如果没有逗号,那么,b 就拿不到输入。

L178 发表于 2022-10-24 15:24:59

jackz007 发表于 2022-10-24 15:01
因为,键盘输入语句 scanf("%f,%f" , & a , & b) ,看到 "%f,%f" 中间的逗号了,这种写法要求键 ...

非常感谢
页: [1]
查看完整版本: 为什么这里max输出的是较小的那个数而不是较大的那个数