我正在尝试使用带有重载 < 运算符的插入排序来订购指针向量(不能使用任何库)。有一个包含另一个类的类,例如:
class A {
vector<B*> v;
void order();
}
class B {
int id; //each one is unique
virtual double num() {} const;
bool operator<(const B* b2) const;
}
class B1: public B {
double num() {} const;
}
class B2: public B {
double num() {} const;
}
每个孩子计算 num 的方式不同,排序是使用 num 返回的 double 作为第一个条件,然后是 id。(对不起缩进)
void A::order() {
for (unsigned int p = 1; p < v.size(); p++)
{
ClassB* tmp = v[p];
int j;
for (j = p; j > 0 && tmp < v[j-1]; j--) // Error on this line
v[j] = v[j-1];
v[j] = tmp;
}
}
bool B::operator<(const B* b2) const {
cout << "Operator <\n";
if(this->num()!=b2->num())
return this->num()<b2->num();
return id<d2->id;
}
我不明白为什么在尝试比较两个指针时没有调用运算符。