输入一个实数,第一次按实型输出;第二次保留2位小数输出;第三次保留3位小数但最小列宽8列输出,空格分隔。
输入格式:
输入实型
输出格式:
输出实型,空格分隔。
输入:
31331.14345435
输出:
31331.143454 31331.14 31331.143
题目有三个要求,第一次按实型输出;第二次保留2位小数输出和空格分隔这几个要求是我们常见的,使用C语言可以很快的写出来,但是对于第三个要求:第三次保留3位小数但最小列宽8列输出,我原先没有见过这种表述,通过查找资料,得到了如下内容。
- %f:整数部分全部输出,并输出6位小数;
- %.nf:整数部分全部输出,并输出n位小数;
- %m.nf:输出共占m列,n位小数,若数值宽度小于m则左端补空格。
依照上述资料,成功实现了题目要求。
#include
using namespace std;
int main( )
{
double a;
cin >> a ;
printf("%f ",a);
printf("%.2f ",a);
printf("%8.3f",a);
return 0;
}
输出3.1415926、12345678.123456789的小数、指数形式。
输入格式:
无
输出格式:
输出为实型,空格分隔
输入:
无
输出:
3.141593 3.141593e+000 12345678.123457 1.234568e+007
看不懂,思密达~,所以,我就去求助小码哥了,嘿嘿。
下面是对小码哥的讲解的理解:
指数形式输出的方式:
1.printf与%e搭配使用;
2.cout<
注意:虽然输出为指数型,但是e后面只有两位数。
而题目要求的是e后面有三位,所以还需要采用其他方法解决。
在科学计数法中,为了使公式简便,可以用带“E”的格式表示。当用该格式表示时,E前面的数字和“E+”后面要精确到十分位,(位数不够末尾补0),例如7.8乘10的7次方,正常写法为:7.8x10^7,简写为“7.8E+07”的形式
小数点左移几位,就乘以10的相应次方;右移几位,就是乘以10的负几次方。
输出3.1415926、12345678.123456789的小数、指数形式。
输出:
3.141593 3.141593e+000 12345678.123457 1.234568e+007
对于第一个输出(输出的第一列)不难看出,就是保留小数点后六位,所以按照平时常用的.6f%就可,但是对于后面的一个输出,发现它是e后面有三个数,而默认的科学计数法是两位数,所以这就需要我们自己把后面这三位数表示出来。
首先不能使用默认的方式,所以e+肯定需要自己输出,除此之外,我们需要自己按照科学计数法的方式来计算e前的数和e后的数。
通过分析可以发现e前小数点后也有六位数字,所以就需要我们首先将所给数化成科学计数法的那种形式(整数部分大于0小于10),然后直接按照.6f%输出,而e后的数字就是转成科学计数法表示时小数点移动的次数,所以在转换成科学计数法的时候需要设置一个计数的变量来表示e后的数字。
但是,问题还没有解决,再此题中要求e后有三位数字,而指数在最后一位表示,所以,前面的位置需要使用0进行填充,此时就需要用到setfill('0')
来设置输出流中的填充字符,并使用 setw(3)
来设置输出宽度。这样就可以满足题意了。
在C++中,setw(int n)用来控制输出间隔,可以设置相应的宽度,要想实现其他字符填充,可以与setfill()配合使用。
例:在本题中,e后的数字个数为3,那么设置宽度为3,即setw(3),前面用'0'填充,即setfill('0')。
所以语句为:
cout << setw(3) << setfill('0') << i;
#include
using namespace std;
double a = 3.1415926 ,b = 12345678.123456789;
void solve(double a){
printf("%f ",a);
int i = 0;
while(a>10){
a/=10.0;
i++;
}
printf("%.6fe+",a);
cout << setw(3) << setfill('0') << i;
}
int main( )
{
solve(a);
cout << endl;
solve(b);
return 0;
cout << a << endl ;
printf("%f ",b);
cout << b ;
return 0;
}
明天继续吧。