C++输出精度问题
本帖最后由 mmmidori 于 2020-3-27 11:40 编辑C++ double型数据输出,比如输入 8 9 0 7.8,排序之后怎样输出能输出 0 7.8 8 9,而不是0.0 7.8 8.0 9.0 或者是0 8 8 9
代码:
[*]sort(num,num+4);
[*] cout.setf(ios::fixed);
[*] for(i=0;i<2;i++)
[*] {
[*] cout<<setprecision(1)<<num<<" ";
[*] }
[*] cout<<endl;
[*] for(i=0;i<3;i++)
[*] {
[*] cout<<setprecision(1)<<num<<" ";
[*] }
[*] cout<<endl;
[*] for(i=0;i<4;i++)
[*] {
[*] cout<<setprecision(1)<<num<<" ";
[*] }
[*] cout<<endl;
[*] sort(anothernum,anothernum+n);
[*] for(i=0;i<n;i++)
[*] {
[*] cout<<anothernum<<" ";
[*] }
[*] cout<<endl;
//前面还要排列另外一个数组,需要按小数点后保留一位的精度输出。 那你要在输入的时候就判断是什么类型了。
c可没那么智能。 兄弟,你的代码中是不是原来有呢 本帖最后由 Ranbo_ 于 2020-3-27 13:19 编辑
我没学过C++,但是C语言里我可以提供一种四舍五入的方法
假设要将输入的变量data四舍五入:
double data;
scanf("%lf", &data);
int integer_data = (data + 0.5) / 1;
printf("%d\n", integer_data);
这样处理后的integer_data就是四舍五入的结果了,同理可以计算保留n位有效数字的四舍五入的结果。
但是如果几个不同的数的精度不同,那就需要一个一个按照不同精度输出,也可以使用printf函数用%g去浮点数的最后的不必要的0,但是这样就没有四舍五入。
double data;
scanf("%lf", &data);
printf("%g\n", integer_data);
页:
[1]