mmmidori 发表于 2020-3-27 11:37:30

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;

//前面还要排列另外一个数组,需要按小数点后保留一位的精度输出。

ba21 发表于 2020-3-27 12:02:53

那你要在输入的时候就判断是什么类型了。
c可没那么智能。

永恒的蓝色梦想 发表于 2020-3-27 13:16:38

兄弟,你的代码中是不是原来有呢

Ranbo_ 发表于 2020-3-27 13:16:47

本帖最后由 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]
查看完整版本: C++输出精度问题