首页 > 解决方案 > Boost C++如何输出没有指数字符的浮点值的所有数字?

问题描述

    #include <iostream>
    #include <boost/multiprecision/cpp_dec_float.hpp>
    #include <boost/multiprecision/cpp_int.hpp>
    using boost::multiprecision::number;
    using boost::multiprecision::cpp_dec_float;
    using boost::multiprecision::cpp_dec_float_50;
    using boost::numeric_cast;
    using std::cout;


    int main()
    {
        srand(time(NULL));


        std::cout << std::setprecision(std::numeric_limits<cpp_dec_float_50>::digits10);
        cpp_dec_float_50 x = 0.0001;
        cpp_dec_float_50 y = x*x*x*x;
        std::cout << s << "\n";
    }

所以我按照这里的文档:https ://www.boost.org/doc/libs/1_63_0/libs/multiprecision/doc/html/boost_multiprecision/tut/floats/cpp_dec_float.html

我期望得到的输出是:0.00000000000000000001(20 个零)

但是程序的输出是: 在此处输入图像描述

对于这个问题,我只想删除“e^-16”部分。我怎样才能做到这一点?此外,如果其他人可以帮助我输出确切的值,那也会很有帮助。

谢谢你。

标签: c++boostprecisionboost-multiprecision

解决方案


您已x使用二进制双精度值进行实例化,该值不能表示为十进制。以下是解决方法:

#include <iostream>
#include <boost/multiprecision/cpp_dec_float.hpp>

using boost::multiprecision::cpp_dec_float_50;

int main()
{   
    std::cout << std::setprecision(std::numeric_limits<cpp_dec_float_50>::digits10);
    cpp_dec_float_50 x{"0.0001"};
    cpp_dec_float_50 y = x*x*x*x;
    std::cout << std::fixed;
    std::cout << y << "\n";
}

输出:

0.00000000000000010000000000000000000000000000000000

推荐阅读