STL 排序,保留原始顺序
STL sort with retaining the original order
我想按大小对字符串向量进行反向排序,但约束条件是,如果有 2 个长度相等的字符串,我希望它们保留其原始顺序。例如:对以下一组字符串进行排序:-
aab
aac
aacghgh
aabghgh
应该让步:-
aacghgh
aabghgh
aab
aac
目前我正在按如下方式进行排序:-
struct comp_functor {
bool operator()(const string& s1, const string& s2) {
return s1.size() > s2.size();
}
};
struct comp_functor c;
vector<string> vecs;
sort(vecs.begin(), vecs.end(), c);
有什么方法可以在重载方法中指定如果它们具有相同的长度,我想保留原始排序?如果没有,使用 STL 库解决此问题的最佳方法是什么?
我相信
你正在寻找std::stable_sort
.它保留了被视为相等的元素的顺序。
如果您不希望等效元素更改顺序,则不要使用 std::sort
。改用 std::stable_sort - 它之所以存在,正是因为它具有不对等效元素进行重新排序的属性。
相关文章:
- CMake-按正确顺序将项目与C运行时对象文件链接
- 函数调用中参数的顺序重要吗
- 为什么不;名字在地图上是按顺序排列的吗
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 数到第n个楼梯的路(顺序无关紧要)
- 优先顺序:智能指针和类析构函数
- 在循环中按顺序遍历成员变量
- 独立读取-修改-写入顺序
- QML按钮点击功能执行顺序
- 将浮动的heightmap数组导出为16位原始值
- 给定一个向量,如何找到该向量的所有子集和的原始索引
- C++中数据类型修饰符的顺序
- 当比特(而不是字节)的顺序至关重要时的持久性
- C++从其他 constexpr 创建 lambda 不能按顺序执行 Constexpr
- 有没有办法从非C/C++文件中读取C++原始字符串文字的内容
- 通过选项卡的文本设置QTabWidget顺序
- c++11评估顺序(未定义的行为)
- STL 排序,保留原始顺序
- 原始数据包创建导致 IP 字段顺序不正确
- 查找从数组中删除原始元素的顺序