C语言得到的数保留两位小数应该怎么写语句?
是得到的,存在内存里的,不是%.2f那样输出的。比如:a=b=1.1325;c=a+b;d=1+c;printf("c=%.2f",c);printf("d=%f",d)...
是得到的,存在内存里的,不是%.2f那样输出的。比如:a=b=1.1325;c=a+b;d=1+c;printf("c=%.2f",c);printf("d=%f",d);这样输出的c肯定是保留两位的,但d肯定不是,我想让d直接成保留两位小数的。
展开
5个回答
展开全部
如果需要保留2位小数,那么就要在输出函数printf函数中规定输出格式了。
具体格式如下:
printf("%.2f"); // 使输出的数按四舍五入的准则保留2位小数,不足2位就在后面补0
更一般的表示如下:
printf("%a.bf"); // 其中a, b都表示整数。输出格式如下:
// 此帆整数部分按a位的固定位宽输出(不足a位森高雹就在前面补空格,大于a位就按实际位数念亮输出)
// 小数部分按四舍五入的准则保留b位小数(不足b位就在后面补0)
展开全部
可以先让d乘100再加上0.5;然后就是将d采用强制类型转换为int类型赋给变量e(假悄瞎设名字采用的是e);最后就是让e除册运旁100后强制州橡类型转换为float类型赋给d就可以了!
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
简单的来讲,这是不可能做到的,
内行樱存里的数的形亏带并态不是由你管理的,
是由编译器和运行时环境管理的,
同时也跟处理器销迹的浮点数格式有关。
内行樱存里的数的形亏带并态不是由你管理的,
是由编译器和运行时环境管理的,
同时也跟处理器销迹的浮点数格式有关。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2012-05-11
展开全部
float GetWanaNum(float n,int iLen=2)//麻烦了点,但可以选择保留的槐册小数位数,最多6位
{
char szTemp[64] = {0};
char szOut[64] = {0};
int iCount = 0;
sprintf(szTemp,"%f",n);
for (int i=0; ; i++ )
{
if ( iCount <桥晌= 2 )
{
szOut[i] = szTemp[i];
}
else
{
break;
}
if ( iCount )
{
iCount++;
}
if ( szTemp[i] == '.'敏明锋 )
{
iCount++;
}
}
return atof(szOut);
}
{
char szTemp[64] = {0};
char szOut[64] = {0};
int iCount = 0;
sprintf(szTemp,"%f",n);
for (int i=0; ; i++ )
{
if ( iCount <桥晌= 2 )
{
szOut[i] = szTemp[i];
}
else
{
break;
}
if ( iCount )
{
iCount++;
}
if ( szTemp[i] == '.'敏明锋 )
{
iCount++;
}
}
return atof(szOut);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
printf("d=%.2f",d);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询