ไลบรารีบูสต์ C ++ เป็นไลบรารีที่มีประโยชน์อย่างกว้างขวาง ใช้สำหรับส่วนต่างๆ มีโดเมนแอปพลิเคชันขนาดใหญ่ ตัวอย่างเช่น การใช้บูสต์ เราสามารถใช้ตัวเลขจำนวนมาก เช่น 264 ใน C++
เราจะมาดูตัวอย่างบางส่วนของ Boost Library เราสามารถใช้ประเภทข้อมูลจำนวนเต็มขนาดใหญ่ได้ เราสามารถใช้ประเภทข้อมูลต่างๆ เช่น 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
ประเภทข้อมูลอีกประเภทหนึ่งคือ Arbitrary Precision Datatype ดังนั้นเราจึงสามารถใช้ความแม่นยำใดๆ โดยใช้ประเภทข้อมูล 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