c语言控制位数
‘壹’ c语言由输入时的格式说明来控制数字输入位数
scanf("%3d");
‘贰’ c语言定义浮点型时可以控制定义的数的有效值位数吗怎么定义
定义的时候不能控制有效值位数,你可以尝试在计算完成后对结果c
进行处理,控制c的精度
如下程序可以实现:
但是必须把c定义为
double
否则有误差:
float
a
=
10,
b
=
3;
float
c;
char
t[4];
float
result;
//double
result;
c
=
a
/
b;
sprintf(t,"%.2f",c);
//将浮点数转换成字符串
result
=
(float)atof(t);
//result
=
atof(t);//将字符串转化成浮点数
‘叁’ C语言中输出时怎样控制小数点后的位数,请举例说明保
举例说明如下:
#include <iostream>
#include <iomanip>
using namespace std;
int main( void )
{
const double value = 12.3456789;
cout << value << endl; // 默认以6精度,所以输出为 12.3457
cout << setprecision(4) << value << endl; // 改成4精度,所以输出为12.35
cout << setprecision(8) << value << endl; // 改成8精度,所以输出为12.345679
cout << fixed << setprecision(4) << value << endl; // 加了fixed意味着是固定点方式显示,所以这里的精度指的是小数位,输出为12.3457
cout << value << endl; // fixed和setprecision的作用还在,依然显示12.3457
cout.unsetf( ios::fixed ); // 去掉了fixed,所以精度恢复成整个数值的有效位数,显示为12.35
cout << value << endl;
cout.precision( 6 ); // 恢复成原来的样子,输出为12.3457
cout << value << endl;
}
‘肆’ c语言如何控制有效位数
如果你小数点后面长度会变,这个需要自己生成格式符号的
如果小数点后面留一位试试这个%7.1lf
‘伍’ C语言如何控制输出数字的有效位数
在用printf输出的时候
使用
例
%5.2f
5位,其中两位小数位,
%-5.2f
左对齐
没有"-“则是右对齐。。等等
。
‘陆’ C语言中输出时怎样控制小数点后的位数,请举例说明
A format specification, which consists of optional and required fields, has
the following form:%[flags]
[width]
[.precision] [{h | l | ll | I | I32 | I64}]type
举个例子:
printf("%.2f", 12345.6789);则会输出12345.67,precision就表示输出小数点后的位数。
‘柒’ C语言如何用变量控制小数位数
楼上解法怎么处理123.456-->123.456000
标准做法是这样的
说明:小数点“.”后面的“*”表示输出位数,具体的数据来自参数表。
printf格式字符串中,与宽度控制和精度控制有关的常量都可以换成变量,方法就是使用一个“*”代替那个常量,然后在后面提供变量给“*”。
例子
#include<stdio.h>
int main(){
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
printf("%.*lf\n",c,a*1.0/b);
return 0;
}