stable_sort
网上关于sort qsort stable_sort 等排序函数的介绍已经很多了,因为前几天用到对STL vector 结构体的排序,遇到的问题记录一下。
在c++类中使用stable_sort,因为要对结构体排序,所以要使用该函数的三个参数的重载,例:stable_sort(vectorArray.begin(), vectorArray.end(),myCmp);
之前写的myCmp函数在.h文件中进行了声明,然后 bool 【类】::myCmp(X , X){return ...} 的方式调用的,但是一直报错:
错误 2 ERROR C3867: “CDicomDlg::myCmp”: 函数调用缺少参数列表;请使用“&CDicomDlg::myCmp”创建指向成员的指针
错误 3 error C2780: “void std::stable_sort(_BidIt,_BidIt)”: 应输入 2 个参数,却提供了 3 个
搞了半天,发现这样调用是不行的,把myCmp函数不作为该类的成员函数,直接在.cpp文件中调用函数 bool myCmp(X , X){return ...} 就好了,错误提示比较诡异,下次注意。
代码示意:
bool myCmp(const calArray& a, const calArray& b)
{
return a.count < b.count;
}
void CDicomDlg::XXX()
{
stable_sort(vectorArray.begin(), vectorArray.end(),myCmp);
}
---------------------------------------------------------------------------
自己的公司,朋友们关注一下 中海岸信息技术有限公司
公司网址:www.icss.cc
中海岸建站:www.cseashore.asia
相关阅读
一、基本概念 1.二叉排序树 二叉排序树(Binary sort tree,BST),又称为二叉查找树,或者是一棵空树;或者是具有下列性质的二叉树: (1)若
1.文件偏移 通常调用read或write每读写一个文件,就会改变文件的读写位置。在linux中同样可以使用lseek函数来修改文件偏移量,即读
greatest (max(one),max(two),max(three))求多列的最大值,oracle中的greatest 函数 已知表TB的数据如下 SQL> select * from tb;
Python product函数介绍 product(A,B)函数,返回A和B中的元素组成的笛卡尔积的元组,具体见如下代码:import itertools for item
常见十大(内部)排序算法 - Sorting Algorithms C++
基本概念 内部和外部排序 内部排序在这里指的是只用到了电脑内存而不使用外存的排序方式。相对的,外部排序就是同时动用了电脑内