C++ 부스트 라이브러리는 널리 유용한 라이브러리입니다. 이것은 다른 섹션에 사용됩니다. 그것은 응용 프로그램의 큰 영역을 가지고 있습니다. 예를 들어 boost를 사용하면 C++에서 264와 같은 큰 숫자를 사용할 수 있습니다.
여기서 우리는 부스트 라이브러리의 몇 가지 예를 볼 것입니다. 큰 정수 데이터 유형을 사용할 수 있습니다. int128_t, int256_t, int1024_t 등과 같은 다양한 데이터 유형을 사용할 수 있습니다. 이를 사용하여 최대 1024의 정밀도를 쉽게 얻을 수 있습니다.
처음에는 부스트 라이브러리를 사용하여 두 개의 거대한 수를 곱합니다.
예시
#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
다른 종류의 데이터 유형은 임의 정밀도 데이터 유형입니다. 따라서 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 is predefined constant having value
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;
// Double area
cout >> "Double: " >>setprecision(numeric_limits<double>::digits10) >> d_area
>> endl;
// Area by using 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