为什么这里max输出的是较小的那个数而不是较大的那个数
本帖最后由 L178 于 2022-10-24 14:10 编辑为什么这里max输出的是较小的那个数而不是较大的那个数,谢谢
题目给的就是int ,然后让解释为什么输出结果是较小的数 本帖最后由 jackz007 于 2022-10-24 13:49 编辑
int max(float x , float y)
函数返回值类型定义错误
float max(float x , float y)
主函数中 int c 也得相应改成 float c,还有 printf("%d") 也得改,说好的浮点数,怎么悄悄改整型数了???
jackz007 发表于 2022-10-24 13:45
函数返回值类型定义错误
主函数中 int c 也得相应改成 float c,还有 printf("%d") ...
题目给的是int,然后让解释为什么输出结果是较小的那个数的 本帖最后由 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 ,看看对结果是否有影响。 jackz007 发表于 2022-10-24 14:25
编译、运行实况:
肯定是因为没有按预期输入,例如,这个代码,要求按 a,b 的格式 ...
是的,但是为什么呢 L178 发表于 2022-10-24 14:33
是的,但是为什么呢
输入19 9,输出就是19
输入9 19,输出就是9 本帖最后由 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 就拿不到输入。 jackz007 发表于 2022-10-24 15:01
因为,键盘输入语句 scanf("%f,%f" , & a , & b) ,看到 "%f,%f" 中间的逗号了,这种写法要求键 ...
非常感谢
页:
[1]