Computer >> 컴퓨터 >  >> 프로그램 작성 >> C++

C++에서 큰 숫자를 처리합니까?

<시간/>

C++에서는 부스트 라이브러리를 사용하여 큰 숫자를 사용할 수 있습니다. 이 C++ 부스트 라이브러리는 널리 사용되는 라이브러리입니다. 이것은 다른 섹션에 사용됩니다. 그것은 응용 프로그램의 큰 영역을 가지고 있습니다. 예를 들어 boost를 사용하면 2 64 와 같은 큰 숫자를 사용할 수 있습니다. C++에서.

여기서 우리는 부스트 라이브러리의 몇 가지 예를 볼 것입니다. 큰 정수 데이터 유형을 사용할 수 있습니다. 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