在对对象的矢量进行排序时,使用stable_sort
Using stable_sort, when sorting vector of objects
我有一个包含变量string name; string station; string ticket;
的class Passanger
然后我有另一个类,在这个类中我有vector<Passanger*> myQueue;
现在我想使用stable_sort
对myQueue
进行排序。有没有可能,怎么对stable_sort
说,关键应该是什么,根据它来排序myQueue
?
std::stable_sort(myQueue.begin(),myQueue.end(), maybeSomethingElse() );
?
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...
});
是的,您需要一个比较器类。它们看起来像这样。
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());
例如,使用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
。
您可以通过指定自己的比较函数来实现这一点。
一些有用的参考:
- stable_sort文档(参见示例比较函数
bool compare_as_ints (double i,double j)
的代码示例( - 函子及其用途
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- C++:TypeDef使用元组
- 使用std::multimap迭代器创建std::list
- 从不同线程使用int64的不同字节安全吗
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么在全局范围内使用"extern int a"似乎不行?
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用Google Mock来模拟gettimeofday()
- 如何使用默认参数等选择模板专业化
- 为什么使用 "this" 指针调用派生成员函数?
- 使用新行和不使用新行读取文件
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 如何确定我已使用非编码文件到达 EOF?
- 如何在cuSparse中使用cusparseXcoo2csr从coo转换为csc
- 使用CMake创建QML插件
- 使用strcpy将char数组的元素复制到另一个数组
- 在c++中使用nlohmann从类到json的转换
- 使用指针从C++中的数组中获取最大值
- 使用不带参数的函数访问结构元素