gpt4 book ai didi

c++ - 如何在 C++ 中进行 32 位十进制 float 乘法?

转载 作者:塔克拉玛干 更新时间:2023-11-03 06:13:35 26 4
gpt4 key购买 nike

我有两个数字是 32 位十进制 float ,比如 1.2345678901234567890123456789012,我想得到乘法也是 32 位十进制 float 。有什么有效的方法可以做到这一点吗?

最佳答案

只需使用boost::multiprecision。您可以使用任意精度,但有一个 typedef cpp_bin_float_50,它是一个带有 50 位小数的 float

乘以大十进制数的示例:

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

int main(){
boost::multiprecision::cpp_bin_float_50 val1("1.2345678901234567890123456789012");
boost::multiprecision::cpp_bin_float_50 val2("2.2345678901234567890123456789012");
std::cout << std::setprecision(std::numeric_limits< boost::multiprecision::cpp_bin_float_50>::max_digits10);
std::cout << val1*val2 << std::endl;
}

输出:

2.7587257654473404640618808351577828416864868162811293

关于c++ - 如何在 C++ 中进行 32 位十进制 float 乘法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44841518/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com