Qsort 和不兼容的比较器函数 - C++
Qsort and incompatible comparator function - C++
我有一个结构 subPolygon
和一个指向该结构的指针向量。我试图在矢量上使用 qsort
但比较器功能显示为不兼容。我究竟做错了什么?
int cmpFunc(const void *p, const void *q) {
struct subPolygon* p1 = *((struct subPolygon**)p);
struct subPolygon* p2 = *((struct subPolygon**)q);
int s1 = p1->size;
int s2 = p2->size;
if (s1-s2 < 0 ) return -1;
if (s1 == s2) return 0;
return 1;
}
这是向量的声明:
vector<subPolygon*> subPolygons;
qsort
调用:
qsort(&subPolygons[0], subPolygons.size(), sizeof(struct subPolygon*),cmpFunc);
编辑:
看来问题是一个额外的错误:
cmpFunc: non-standard synatx; use & to create pointer to a member "
我的比较函数是 class 的成员。 Qsort 是从 class 的成员调用的。使我的比较器函数静态化解决了这个问题。
你真正应该做的:
bool compare(const subPolygon *p1, const subPolygon *p2)
{
int s1 = p1->size;
int s2 = p2->size;
return (s1-s2 < 0);
// Or just: return p1->size < p2->size;
}
std::sort(subPolygons.begin(), subPolygons.end(), compare);
我有一个结构 subPolygon
和一个指向该结构的指针向量。我试图在矢量上使用 qsort
但比较器功能显示为不兼容。我究竟做错了什么?
int cmpFunc(const void *p, const void *q) {
struct subPolygon* p1 = *((struct subPolygon**)p);
struct subPolygon* p2 = *((struct subPolygon**)q);
int s1 = p1->size;
int s2 = p2->size;
if (s1-s2 < 0 ) return -1;
if (s1 == s2) return 0;
return 1;
}
这是向量的声明:
vector<subPolygon*> subPolygons;
qsort
调用:
qsort(&subPolygons[0], subPolygons.size(), sizeof(struct subPolygon*),cmpFunc);
编辑:
看来问题是一个额外的错误:
cmpFunc: non-standard synatx; use & to create pointer to a member "
我的比较函数是 class 的成员。 Qsort 是从 class 的成员调用的。使我的比较器函数静态化解决了这个问题。
你真正应该做的:
bool compare(const subPolygon *p1, const subPolygon *p2)
{
int s1 = p1->size;
int s2 = p2->size;
return (s1-s2 < 0);
// Or just: return p1->size < p2->size;
}
std::sort(subPolygons.begin(), subPolygons.end(), compare);