C++的vector容器使用qsort()和sort()
对vector容器定义的数组可以使用sort排序vector<int> test;sort(test.begin(),test.end());但是使用qsort时,qsort(numbers,len,sizeof(int),compare);//错误用法int compare(const void * arg1, const void *arg2){...
·
对vector容器定义的数组可以使用sort排序,这个很简单
vector<int> test;
sort(test.begin(),test.end());
但是使用qsort时,我这里报错了
note: candidate function not viable: no known conversion from 'vector' to 'void *' for 1st argument; take the address of the argument with &
extern void qsort (void *__base, size_t __nmemb, size_t __size,
qsort(numbers,len,sizeof(int),compare);//错误用法
qsort(&numbers,len,sizeof(int),compare);//错误用法
qsort(&numbers[0],len,sizeof(int),compare);//错误用法
int compare(const void * arg1, const void *arg2)
{
return (*(int*)arg1 - *(int*)arg2);
}
https://stackoverflow.com/questions/24303917/passing-vector-to-qsort
使用qsort,需要把使用原生的数组,也就是说要使用vector数组指针的地址,qsort的第一个参数要使用的要排序数组的指针。使用&entries[0]指向向量的第一个元素的指针,即可解决问题。
更多推荐
已为社区贡献1条内容
所有评论(0)