本文整理汇总了C++中BigInteger::Signum方法的典型用法代码示例。如果您正苦于以下问题:C++ BigInteger::Signum方法的具体用法?C++ BigInteger::Signum怎么用?C++ BigInteger::Signum使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类BigInteger
的用法示例。
在下文中一共展示了BigInteger::Signum方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: BigInteger
const BigInteger BigInteger::operator-(const BigInteger &other) const {
if (Signum() != other.Signum()) {
return (Signum() == Positive ? Negate() : *this) + (other.Signum() == Positive ? other.Negate() : other);
}
if (*this > other) {
int iterationSize = std::max(Size(), other.Size());
unsigned short remainder = 0;
std::vector<unsigned short> digitVector;
for (int i = 0; i < iterationSize; i++) {
unsigned short selfDigit = i < Size() ? mDigits[i] : 0;
unsigned short otherDigit = i < other.Size() ? other.mDigits[i] : 0;
unsigned short toSubstract = otherDigit + remainder;
if (selfDigit >= toSubstract) {
digitVector.push_back(selfDigit - toSubstract);
remainder = 0;
} else {
digitVector.push_back((selfDigit + 10) - toSubstract);
remainder = 1;
}
}
while (digitVector.at(digitVector.size() - 1) == 0) {
digitVector.pop_back();
}
return BigInteger(Signum(), digitVector.size(), CopyOf(digitVector));
} else {
return (other - (*this)).Negate();
}
}
示例2: Signum
bool BigInteger::operator<(const BigInteger &other) const {
if (Signum() == Positive && other.Signum() == Negative) {
return false;
}
if (Signum() == Negative && other.Signum() == Positive) {
return true;
}
if (Size() < other.Size()) {
return Signum() == Positive;
}
if (Size() > other.Size()) {
return Signum() == Negative;
}
// size of the two are equal, and the sign is also equal
for (int i = 0; i < Size(); i++) {
unsigned short selfDigit = mDigits[i];
unsigned short otherDigit = other.mDigits[i];
if (selfDigit != otherDigit) {
return Signum() == Negative ? selfDigit > otherDigit : selfDigit < otherDigit;
}
}
return false;
}
示例3:
bool BigInteger::operator==(const BigInteger &other) const {
if (Signum() != other.Signum()) {
return false;
}
if (Size() != other.Size()) {
return false;
}
for (int i = 0; i < Size(); i++) {
if (mDigits[i] != other.mDigits[i]) {
return false;
}
}
return true;
}