这个运行结果输入一,结果输出的根本想不到,那位大佬能指点一下吗,谢谢!
#include <stdio.h>void main()
{
float sum,d,price;
int z,y,x;
printf("请选择你要加油的品种\n");
printf("1.89号7.88元/升\n");
printf("2.92号8.28元/升\n");
printf("3.95号9.68元/升\n");
scanf("%f",&y);
switch(y)
{
case 1:price=7.88;break;
case 2:price=8.28;break;
case 3:price=9.68;break;
}
printf("请选择你要服务的类型\n");
printf("1:自助加油(5%优惠)\n");
printf("2:加油员加油(2%优惠)\n");
scanf("%f",&z);
switch(z)
{
case 1:d=0.05;break;
case 2:d=0.02;break;
}
printf("请输入你的加油量\n");
scanf("%f",&x);
sum=price*x*(1-d);
printf("%.2f\n",sum);
}
--------------------Configuration: 654 - Win32 Debug--------------------
Compiling...
6554.c
D:\cYUYAN\Microsoft Visual Studio\c++\654\6554.c(13) : warning C4305: '=' : truncation from 'const double ' to 'float '
D:\cYUYAN\Microsoft Visual Studio\c++\654\6554.c(14) : warning C4305: '=' : truncation from 'const double ' to 'float '
D:\cYUYAN\Microsoft Visual Studio\c++\654\6554.c(15) : warning C4305: '=' : truncation from 'const double ' to 'float '
D:\cYUYAN\Microsoft Visual Studio\c++\654\6554.c(24) : warning C4305: '=' : truncation from 'const double ' to 'float '
D:\cYUYAN\Microsoft Visual Studio\c++\654\6554.c(25) : warning C4305: '=' : truncation from 'const double ' to 'float '
6554.obj - 0 error(s), 0 warning(s)
#include <stdio.h>
void main()
{
float sum,d,price;
int z,y,x;
printf("请选择你要加油的品种\n");
printf("1.89号7.88元/升\n");
printf("2.92号8.28元/升\n");
printf("3.95号9.68元/升\n");
scanf("%f",&y);
switch(y)
{
case 1:price=7.88f;break; // 改了这里
case 2:price=8.28f;break; // 改了这里
case 3:price=9.68f;break; // 改了这里
}
printf("请选择你要服务的类型\n");
printf("1:自助加油(5%优惠)\n");
printf("2:加油员加油(2%优惠)\n");
scanf("%f",&z);
switch(z)
{
case 1:d=0.05;break;
case 2:d=0.02;break;
}
printf("请输入你的加油量\n");
scanf("%f",&x);
sum=price*x*(1-d);
printf("%.2f\n",sum);
} 把 price 改成 double 类型就好了 为什么你的编译器报错 warning C4305: '=' : truncation from 'const double ' to 'float '
但是 scanf("%f",&z); 和 scanf("%f",&x);却没有报错?z 和 x 不是声明整数吗?输入占位符 %f ? 本帖最后由 C丁洞杀O 于 2022-3-20 18:46 编辑
额,你的占位符不是这样用的, 整数是%d,希望我的答案对你有帮助
#include <stdio.h>
void main()
{
float sum,d,price;
int y,z;
float x;
printf("请选择你要加油的品种\n");
printf("1.89号7.88元/升\n");
printf("2.92号8.28元/升\n");
printf("3.95号9.68元/升\n");
scanf("%d",&y);
switch(y)
{
case 1:price=7.88f;break;
case 2:price=8.28f;break;
case 3:price=9.68f;break;
}
printf("请选择你要服务的类型\n");
printf("1:自助加油(5%优惠)\n");
printf("2:加油员加油(2%优惠)\n");
scanf("%d",&z);
switch(z)
{
case 1:d=0.05;break;
case 2:d=0.02;break;
}
printf("请输入你的加油量\n");
scanf("%f",&x);
sum=price*x*(1-d);
printf("%.2f\n",sum);
} 傻眼貓咪 发表于 2022-3-20 18:28
为什么你的编译器报错 warning C4305: '=' : truncation from 'const double ' to 'float '
但是 scanf("% ...
不知道啊,把z和x后面输出形式改成整型之后,再把上面其他的定义成double之后,这样才能运行;
但是为什么float单精度运行出来不出来结果? 牛肉我刚开始 发表于 2022-3-30 22:58
不知道啊,把z和x后面输出形式改成整型之后,再把上面其他的定义成double之后,这样才能运行;
但是为什 ...
可能因为不同编译器不同效果吧{:10_281:}
页:
[1]