C++类运算符重载不适用于 std::sort
C++ class operator overloads don't work with std::sort
,所以我一直在尝试建立一个中位数发电机,该发生器占据分数并生成中位数,但是目前我似乎无法对我自定义的理性number类的向量进行分类。我已经超载了许多操作员( * /==等(,但是当在其他地方向上调用时,它们似乎不起作用。
RationalNumber RationalNumber::operator*(const RationalNumber& r)
{
RationalNumber result(numerator * r.numerator, denominator * r.denominator);
result.reduceFraction();
return result;
}
RationalNumber RationalNumber::operator*(int x)
{
RationalNumber result(numerator * x, denominator);
result.reduceFraction();
return result;
}
RationalNumber RationalNumber::operator/(const RationalNumber& r)
{
RationalNumber result(numerator * r.denominator, denominator * r.numerator);
result.reduceFraction();
return result;
}
RationalNumber RationalNumber::operator/(int x)
{
RationalNumber result(numerator, denominator * x);
result.reduceFraction();
return result;
}
bool RationalNumber::operator<(const RationalNumber& r)
{
if(this->floatingPoint < r.floatingPoint)
{
return true;
}
return false;
}
bool RationalNumber::operator<(int x)
{
if(floatingPoint < (double) x)
{
return true;
}
return false;
}
bool RationalNumber::operator>(const RationalNumber& r)
{
if(floatingPoint > r.floatingPoint)
{
return true;
}
return false;
}
bool RationalNumber::operator>(int x)
{
if(floatingPoint > (double) x)
{
return true;
}
return false;
}
RationalNumber RationalNumber::operator+(const RationalNumber& r)
{
RationalNumber result((numerator * r.denominator)+(r.numerator*denominator),denominator * r.denominator);
result.reduceFraction();
return result;
}
RationalNumber RationalNumber::operator+(int x)
{
RationalNumber result(numerator * x,denominator);
return result;
}
因此,在这里,我有一个类,旨在用过载的运算符代表理性数字,目的是为了执行算术。但是,当在主类中执行以下操作时:
RationalNumber medianCalculator(std::vector<RationalNumber*> &listOfRationalNumbers)
{
std::sort(listOfRationalNumbers.begin(),listOfRationalNumbers.end());
if(!(listOfRationalNumbers.size() % 2)){
return ((RationalNumber(*listOfRationalNumbers.at((listOfRationalNumbers.size()/2) +1)) + (RationalNumber(*listOfRationalNumbers.at(listOfRationalNumbers.size()/2))) / 2));
} else {
return RationalNumber(*listOfRationalNumbers.at(listOfRationalNumbers.size() +1));
}
}
首先,它似乎会产生范围范围的异常,但更重要的是,似乎操作员的过载似乎没有奏效,因为STD :: Sort Call似乎不起作用或算术。
肯定会错误地超载运算符。例如,此代码将产生意外结果:
RationalNumber num(1, 1);
num *= 2;
// num is still 1/1
正确的实现应为:
RationalNumber& RationalNumber::operator*(int x)
{
numerator *= x;
reduceFraction();
return *this;
}
其余方法应相应实施。
相关文章:
- std::sort()函数无法对向量的一部分进行排序
- 使用自定义比较函数使用std::sort()对矢量字符串进行排序时出现问题
- C++中"std::sort"比较器的不同类型
- 将用户定义的类型与 std::vector 和 std::sort 一起使用
- 使用 std::sort 对向量进行稳定排序
- std::sort 如何处理重复的数字?
- 为什么 std::sort 找不到合适的(静态成员)函数重载?
- 使用 std::sort 对二维 c 数组进行排序
- std::stable_sort vs std::sort
- 使用 std::sort 对 C 样式的 2D 数组进行部分排序
- std::vector 未按 std::sort 的预期排序
- 隐式转换为比较函数对象(函子)用于 std::sort 而不是 std::map?
- 为什么只有当我的容器有超过 32 个元素时才由 std::sort 调用交换?
- 在 c++ 中使用 std::sort 与迭代器和模板
- 使用类似的比较函数时,在 c++ 中为 std:sort 获得不同的结果
- 相同的结果 qsort vs std::sort
- 通过 std::sort 对 C 2D 数组进行排序
- 对整个范围进行排序时,std::p artial_sort() 与 std::sort() 的性能?
- 在使用 std::sort() 和 lambda 函数按属性对 ADT 的向量进行排序时遇到问题
- 使用 std::sort 对矩阵进行排序