对向量进行排序的最快方法是什么
what is the fastest way of sorting a vector?
我想根据距离变量对"mystruct"进行排序,最快的方法是什么?
struct MyStruct {
int scale;
bool pass;
float distance;
};
vector<MyStruct> mystruct;
...
sort (mystruct.begin(), mystruct.begin() + mystruct.size());
//this doesn't work since is trying to sort by "MyStruct" and not by a number
如果我有
vector<float> myfloat;
...
sort (myfloat.begin(), myfloat.begin() + myfloat.size());
然后将完美工作。
您需要为结构编写自己的operator<
。
它应该是类似的东西
bool operator<( const MyStruct& s1, const MyStruct& s2 )
{
// compare them somehow and return true, if s1 is less than s2
// for your case, as far as I understand, you could write
// return ( s1.distance < s2.distance );
}
另一种选择是编写一个函数对象,但在这里没有必要,编写operator<
更容易(对于初学者)
您需要为排序函数提供一个函子,或者提供一个小于运算符:
struct MyStruct_Compare {
bool operator()(const MyStruct& a, const MyStruct& b) {
return a.distance < b.distance;
}
}
std::sort(mystruct.begin(), mystruct.end(), MyStruct_Compare());
或:
bool operator<(const MyStruct& a, const MyStruct& b) {
return a.distance < b.distance;
}
std::sort(mystruct.begin(), mystruct.end());
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 通过JNI传递数据数组的最快方法是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么
- 当无法使用模板和宏时,生成类型变体C++代码的最简单方法是什么?
- 在另一个类视图中添加最多2个图表的正确方法是什么
- 在C++中样板"冷/never_inline"错误处理技术的最佳方法是什么?
- 在 c++ 中对类中的 c 字符串动态数组进行排序的最佳方法是什么?
- 在C++中包含原型文件的正确方法是什么?
- 在 OpenCV C++ 中估计基本矩阵之前对相应点进行归一化的正确方法是什么?
- 在PostgreSQL中根据它们的ID选择大量行的最快方法是什么?
- 在OSX上使用CMake将Adobe的XMP工具包构建为共享库的最简单方法是什么?
- 将一系列整数放入类的最佳方法是什么?
- 从长整整转换为uint64_t的推荐方法是什么?
- 将此布尔值传递给此函数的最有效方法是什么?
- 通过比较C++中的行在 txt 文件中搜索的最简单方法是什么?