我class Passanger
有变量string name; string station; string ticket;
然后我有另一个班级,在这个班级里我有vector<Passanger*> myQueue;
现在我想使用stable_sort
对myQueue
进行排序。有没有可能,如何对stable_sort
说什么应该是关键,根据它应该排序myQueue
?
std::stable_sort(myQueue.begin(),myQueue.end(), maybeSomethingElse() );
?
答案 0 :(得分:13)
有std::stable_sort()
的重载接受自定义比较器作为其第三个参数。你可以在那里提供一个比较函数,一个函子或一个lambda(在C ++ 11中)。与lambda一起使用,例如:
std::stable_sort(myQueue.begin(),myQueue.end(), [] (Passenger* p1, Passenger* p2)
{
return p1->age() < p2->age(); // Or whatever fits your needs...
});
答案 1 :(得分:7)
是的,你需要一个比较器类。它们看起来像这样。
class CompareFoo {
public:
bool operator() (const Foo* e1, const Foo* s2)
{
return e1->name < e2->name; // strict weak ordering required
}
};
然后将其实例化作为参数传递给stable_sort
。
std::stable_sort(myQueue.begin(), myQueue.end(), CompareFoo());
答案 2 :(得分:3)
使用lambda定义比较器(如果排序依赖于Passanger
的多个属性,则使用std::tie
):
std::stable_sort(myQueue.begin(),
myQueue.end(),
[](Passanger* p1, Passanger* p2)
{
return std::tie(p1->name(), p1->station()) <
std::tie(p2->name(), p2->station());
});
如果c ++ 11不可用,请在别处定义比较器并使用boost::tie
。
答案 3 :(得分:1)
您可以通过指定自己的比较功能来完成此操作。
一些有用的参考资料:
bool compare_as_ints (double i,double j)
的代码示例)