5

我有class Passanger变量string name; string station; string ticket; ,然后我有另一个类,在这个类中我有vector<Passanger*> myQueue;

现在我想用stable_sort排序myQueue。有没有可能,怎么说呢stable_sort,应该是什么key,按照它应该排序myQueue

std::stable_sort(myQueue.begin(),myQueue.end(), maybeSomethingElse() );?

4

4 回答 4

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...
});
于 2013-05-18T14:03:18.993 回答
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());
于 2013-05-18T14:04:16.060 回答
3

例如,使用 lambda 定义比较器(std::tie如果排序依赖于 的多个属性Passanger):

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.

于 2013-05-18T14:04:31.373 回答
1

您可以通过指定自己的比较函数来做到这一点。

一些有用的参考:

于 2013-05-18T14:02:50.700 回答