
?正在进行中?
将单包标头文件下载到您的包含路径下的位置。然后在您的代码中#include :
# include " BigInt.hpp " // the actual path may vary创建BigInt类的对象,然后做您必须做的事情!
BigInt big1 = 1234567890 , big2;
big2 = " 9876543210123456789098765432101234567890 " ;
std::cout << big1 * big2 * 123456 << " n " ;
// Output: 1505331490682966620443288524512589666204282352096057600 =第二个操作数可以是BigInt ,一个整数( long long )或字符串( std::string或字符串字面)。
big1 = 1234567890 ;
big1 = " 123456789012345678901234567890 " ;
big1 = big2;+ , - big1 = +big2; // doesn't return the absolute value
big1 = -big2;+ , - , * , / , %其中一个操作数必须是一个BigInt ,另一个可以是BigInt ,一个整数( long long )或字符串( std::string或字符串字面)。
big1 = big2 + 1234567890 ;
big1 = big2 - " 123456789012345678901234567890 " ;
big1 = big2 * big3;
big1 = 1234567890 / big2;
big1 = " 123456789012345678901234567890 " % big2;+= , -= , *= , /= , %=第二个操作数可以是BigInt ,一个整数( long long )或字符串( std::string或字符串字面)。
big1 += big2;
big1 -= 1234567890 ;
big1 *= " 123456789012345678901234567890 " ;
big1 /= big2;
big1 %= 1234567890 ;++ , -- big1 = ++big2; // pre-increment
big1 = --big2; // pre-decrement
big1 = big2++; // post-increment
big1 = big2--; // post-decrement < , > , <= , >= , == , !=其中一个操作数必须是一个BigInt ,另一个可以是BigInt ,一个整数( long long )或字符串( std::string或字符串字面)。
if (big1 < 1234567890
or big1 > " 123456789012345678901234567890 "
or big1 <= big2
or 1234567890 >= big1
or " 123456789012345678901234567890 " == big1
or big1 != big3) {
...
}<< , >> std::cout << big1 << " , " << big2 << " n " ;
output_file << big1 << " , " << big2 << " n " ;
std::cin >> big1 >> big2;
input_file >> big1 >> big2;to_string , to_int , to_long , to_long_long将BigInt转换为string , int , long或long long 。
注意:如果BigInt超出了目标类型的范围,则会引发一个OUT_OF_RANGE异常。
some_str = big1.to_string();
some_int = big1.to_int();
some_long = big1.to_long();
some_long_long = big1.to_long_long();abs获取BigInt的绝对价值。
big1 = abs(big2);big_pow10获得等于10 exp的BigInt 。
big1 = big_pow10( 5000 ); // big1 = 10^5000 gcd获得两个BigInt s的最大共同分裂(aka。hcf)。其中一个参数可以是整数( long long )或字符串( std::string或字符串字面)。
big1 = gcd(big2, big3);
big1 = gcd(big2, 1234567890 );
big1 = gcd(big2, " 123456789012345678901234567890 " );
big1 = gcd( 1234567890 , big2);
big1 = gcd( " 123456789012345678901234567890 " , big2);lcm获得两个BigInt s的最小常见倍数(LCM)。其中一个参数可以是整数( long long )或字符串( std::string或字符串字面)。
big1 = lcm(big2, big3);
big1 = lcm(big2, 1234567890 );
big1 = lcm(big2, " 123456789012345678901234567890 " );
big1 = lcm( 1234567890 , big2);
big1 = lcm( " 123456789012345678901234567890 " , big2);pow将基本经验值作为BigInt的价值。底座可以是一个BigInt ,一个整数( long long )或字符串( std::string或字符串字面)。
big1 = pow(big2, 789 );
big1 = pow( 987654321LL , 456 ); // suffix literal with LL to prevent conflicts
big1 = pow( " 1234567890 " , 123 );sqrt获取BigInt的整数平方根。
big1 = sqrt(big2);big_random获取一个随机的BigInt ,即具有随机数字(最多1000个)或特定数量的数字数字。
// get a random BigInt that has a random number of digits (up to 1000):
big1 = big_random();
// get a random BigInt that has 12345 digits:
big1 = big_random( 12345 );由于该项目是作为仅标题库的构建的,因此没有源文件。但是,每个标头文件都有将项目分为单位测试。这些可以通过命令行进行编译和构建,也可以使用对Cmake直接支持的IDE(例如CLION,QT创建者),也可以使用CMake可以生成项目文件(Visual Studio,Eclipse CDT,Code :: Blocks等)的IDE。
在Linux和MacOS上,您可以使用项目根目录中的命令行来编译和运行测试。
make 。make test 。make release 。生成的文件将出现在release文件夹中。Settings > Build > CMake中找到,请设置build的Generation path 。然后,您只需选择要构建/运行的目标(单位测试),其余的IDE将完成。
如果您的IDE不直接支持CMAKE,则需要通过命令行运行cmake ,并带有适当的标志来为您的IDE生成项目文件。尝试一下,不应该很难!
请阅读有关如何为该项目贡献的详细信息的贡献指南。
该项目是根据MIT许可证的条款获得许可的。