Qsort和不兼容的比较器功能 - C ++

时间:2018-04-30 11:06:26

标签: c++ qsort

我有一个结构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 " 我的比较器函数是一个类的成员。 Qsort是从该类的成员调用的。使我的比较器功能静态解决了这个问题。

1 个答案:

答案 0 :(得分:6)

你应该做什么:

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);