满意答案
seld
2013.08.10
采纳率:44% 等级:8
已帮助:61人
没大问题呀,就是
d=d+a[i]*b[i];}
后面多了一个“}”,去掉就可以运行了。
d=(d*100+0.5)/100的本意是对的,但是会结果不对,至少得改为:
d=(int)(d*100+0.5)/100.0f,结果才可能理解,否则输出时对整数会多出一个从0.005舍入得到的.01来。因为在“%10.2f“格式时printf会自动对小数点后第3位进行舍入操作,所以这一步应该去掉为好。
输入时注意输入格式,品名 数量 单价之间都用空格分开,不能用别的。
没说总的项数,可以用输入的数量或单价作为结束标志,比如输入-1时就结束循环:
do {...} while(a[i]<0 || b[i] <0)。
其实这里的a和b都不需要用数组,因为就输入时用一次,直接设为普通变量就够了;c保存输入的品名,在程序中完全没有用到,根本不用输入的。就是说,最后代码可以这样写:
int main()
{
int i=0,a;
float b,d=0;
while(1)
{
scanf("%f%d",&b,&a);
if ( a == -1 ) break;
d=d+a*b;
}
printf("%10.2f",d);
return 0;
}追问: d=(int)(d*100+0.5)/100.0; 当中
加int是把哪一部分强制准换?
追答: 是把(d*100+0.5)这一部分转换为整型,把小数部分丢弃。然后除以float型的常数“100.0f”(注意最后有个"f",否则默认是double型的,编译时会得到警告)时,再把整数转换为float然后做除法。
比如d=0.005时,(int)(d*100+0.5)/100.0f =(int)(0.005*100+0.5)/100.0f=1/100.0f=0.01
比如d=0.008时,(int)(d*100+0.5)/100.0f =(int)(1.3)/100.0f=1/100.0f=0.01
否则,如果d=0时,(d*100+0.5)/100 =0.5/100=0.005,这是一个double型的值,因为0.5被认为是double型的。这个结果按%10.2f格式输出时就变成0.01了。
00分享举报