conversion from 'double ' to 'float ', possible loss of data请教各位大虾这个错误怎么改呢?
intcunqi;floatbenjin,lixi;printf("pleaseinputbenjin,cunqi:");scanf("%f,%d",&benjin,&c...
int cunqi;float benjin,lixi;
printf("please input benjin,cunqi:");
scanf("%f,%d",&benjin,&cunqi);
switch(cunqi)
{
case 1:lixi=benjin*cunqi*3.15/100.0;break;
这个是程序改的,我没分啊,但我是正确的,请问怎么该才是正确的呢? 展开
printf("please input benjin,cunqi:");
scanf("%f,%d",&benjin,&cunqi);
switch(cunqi)
{
case 1:lixi=benjin*cunqi*3.15/100.0;break;
这个是程序改的,我没分啊,但我是正确的,请问怎么该才是正确的呢? 展开
2个回答
展开全部
lixi=benjin*cunqi*3.15/100.0;改为lixi=float(benjin*cunqi*3.15/100.0);就可以了,另外,你说的这个应该不是错误,只是一个warning吧,因为float类型变量表示的小数范围比较小,但是在lixi=benjin*cunqi*3.15/100.0;这个运算以后,等号后面这个式子的运算结果超过了float所能表示的小数范围,所以会自动把结果转化为表示范围更大的double类型,但是你lixi这个变量还是float的,所以就会有这个警告,解决的方法就是像我刚才说的那个一样改,不过那样可能会丢失结果的小数精度,另外一种方法就是直接定义为double benjin,lixi;就好了
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询