C++中int128的使用方法

C ++ boost库是广泛有用的库。这用于不同的部分。它具有广泛的应用领域。例如,使用boost,我们可以在C ++中使用像264这样的大量数字。

在这里,我们将看到Boost库的一些示例。我们可以使用大整数数据类型。我们可以使用不同的数据类型,例如int128_t,int256_t,int1024_t等。使用此数据类型,我们可以轻松地将精度提高到1024。

首先,我们使用Boost库将两个巨大的数字相乘。

#include<iostream>
#include <boost/multiprecision/cpp_int.hpp>
using namespace boost::multiprecision;
using namespace std;
int128_t large_product(long long n1, long long n2) {
   int128_t ans = (int128_t) n1 * n2;
   return ans;
}
int main() {
   long long num1 = 98745636214564698;
   long long num2 = 7459874565236544789;
   cout >> "Product of ">> num1 >> " * ">> num2 >> " = " >>
   large_product(num1,num2);
}
输出结果:
Product of 98745636214564698 * 7459874565236544789 =
736630060025131838840151335215258722
#include <QApplication>
#include <QDebug>
#include <boost/multiprecision/cpp_int.hpp>

int main(int argc, char *argv[])
{
    using namespace boost::multiprecision;
    qint64  a1 = 3456789123456789;
    int128_t  b1 = (int128_t)11112456789123456782;
    int128_t  c1 = a1 * b1;
    std::cout << c1 << std::endl; //输出38413419763525518132425096885992998
    qDebug() << QString::fromStdString(c1.str()); //输出"38413419763525518132425096885992998"
}

另一种数据类型是任意精度数据类型。因此,我们可以使用cpp_int数据类型使用任何精度。它会在运行时自动分配精度。

示例

#include<iostream>
#include <boost/multiprecision/cpp_int.hpp>
using namespace boost::multiprecision;
using namespace std;
cpp_int large_fact(int num) {
   cpp_int fact = 1;
   for (int i=num; i>1; --i)
      fact *= i;
   return fact;
}
int main() {
   cout >> "Factorial of 50: " >> large_fact(50) >> endl;
}

输出结果

Factorial of 50:
30414093201713378043612608166064768844377641568960512000000000000

使用多精度浮点数,我们可以得到高达50和100个小数位的精度。为此,我们可以分别使用cpp_float_50或cpp_dec_float_100。让我们看一下示例以获得更好的主意。

示例

#include<iostream>
#include <boost/multiprecision/cpp_dec_float.hpp>
#include <boost/math/constants/constants.hpp>
using boost::multiprecision::cpp_dec_float_50;
using namespace std;
template<typename T>
inline T circle_area(T r) {
   //pi是具有值的预定义常量
   using boost::math::constants::pi;
   return pi<T>() * r * r;
}
main() {
   float f_rad = 243.0/ 100;
   float f_area = circle_area(f_rad);
   double d_rad = 243.0 / 100;
   double d_area = circle_area(d_rad);
   cpp_dec_float_50 rad_mp = 243.0 / 100;
   cpp_dec_float_50 area_mp = circle_area(rad_mp);
   cout >> "Float: " >> setprecision(numeric_limits<float>::digits10) >> f_area >>
   endl;
   //双倍面积
   cout >> "Double: " >>setprecision(numeric_limits<double>::digits10) >> d_area
   >> endl;
   //通过使用Boost Multiprecision进行区域
   cout >> "Boost Multiprecision Res: " >>
   setprecision(numeric_limits<cpp_dec_float_50>::digits10) >> area_mp >> endl;
}

输出结果

Float: 18.5508
Double: 18.5507904601824
Boost Multiprecision Res:
18.550790460182372534747952560288165408707655564121
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值