浅谈C/C++排序函数中cmp()比较函数的写法
来源:互联网 发布:linux 访问smb 编辑:程序博客网 时间:2024/06/08 04:32
个人总结:
1. sort中cmp的参数类型为值,返回类型为bool,比较过程用>和<,升序为a<b,降序为a>b
2. qsort中cmp的参数类型为const void*,返回类型为int,升序为a-b,降序为b-a
3. STL容器用sort排序
- #include <cstdio>
- #include <cstdlib>
- #include <iostream>
- #include <vector>
- #include <algorithm>
- using namespace std;
- bool cmp(const int a, const int b) {
- return a > b;
- }
- int main(int argc, char const *argv[]) {
- int n;
- while (scanf(“%d”, &n) != EOF) {
- vector<int> a(n, 0);
- for (int i = 0; i < n; ++i) {
- cin >> a[i];
- }
- sort(a.begin(), a.end(), cmp);
- // qsort((void*)a, a.size(), sizeof(int), cmp);
- vector<int>::iterator iter = unique(a.begin(), a.end());
- a.erase(iter, a.end());
- for (int i = 0; i < a.size()-1; ++i) {
- cout << a[i] << ” ”;
- }
- cout << a[a.size()-1] << endl;
- }
- return 0;
- }
}
======================================================================================================================
原文地址:http://blog.csdn.net/lionel_d/article/details/41746135
首先,我们来谈谈大名鼎鼎的void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));
它属于C语言标准库函数,应该是运用最多的了,今天我不是来教你们怎么用qsort的,只是来交流一下排序函数的最后一个参数cmp()(它不仅可以叫cmp,你还可以给他取名叫什么pig啊dog的只要是英文单词都可以,cmp只是人们对compare的一种常用缩写)比较函数的写法。
下面是cmp的写法:
-
int cmp(const void *a ,const void *b) -
{ -
return (int )a - (int )b ; //从小到大排序,把a,b位置反过来就是从大到小 -
}
注意:qsort的cmp()函数千万别写成下面这样
-
//错错错错错错错 错错错错错错错 错错错错错错错 错错错错错错错 -
int cmp(const void *a ,const void *b) -
{ -
return (int )a > (int )b ; // > 与 < 都不行 ! -
} -
//XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
有一次就是写了下面的cmp(),结果排序死活不对!
下面是完整的测试代码:
-
#include <stdio.h> -
#include <stdlib.h> -
-
int cmp(const void *a ,const void *b) -
{ -
return (int )a - (int )b ; //从小到大排序,把a,b位置反过来就是从大到小 -
} -
int main() -
{ -
int a[10]={-1,9,5,7,-11,2,6,8,9,6}; -
qsort(a,10,sizeof(int),cmp); -
for(int i = 0 ; i < 10 ; ++i) -
{ -
printf(”%d ”,a[i]); -
} -
printf(”\n”) ; -
return 0 ; -
}
测试结果:
第二个cmp(),就是void sort( iterator start, iterator end, StrictWeakOrdering cmp );下面是标准声明:
template <class RandomAccessIterator, class Compare> void sort (RandomAccessIterator first, RandomAccessIterator last, Compare comp);
他的头文件是<algorithm>,这个是标准C++头文件里的。
- bool cmp(int a ,int b)
- {
- return a < b ; //从小到大排序,把 < 换成 > 就是从大到小
- }
好的,问题又来了,这个cmp与qsort的cmp不一样了,正好相反,他不能写成下面这样:
- //错错错错错错错 错错错错错错错 错错错错错错错 错错错错错错错
- bool cmp(int a ,int b)
- {
- return a - b ;
- }
- //XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
切记,切记!
下面是sort的测试代码:
- #include <iostream>
- #include <algorithm>
- using namespace std ;
- bool cmp(int a ,int b)
- {
- return a < b ; //从小到大排序,把 < 换成 > 就是从大到小
- }
- int main()
- {
- int a[10]={-1,9,5,7,-11,2,6,8,9,6};
- sort(a,a+10,cmp);
- for(int i = 0 ; i < 10 ; ++i)
- {
- cout<<a[i]<<” ” ;
- }
- cout<<endl ;
- return 0 ;
- }
测试结果:
在C++中,我们经常需要用到set,map等容器,他们的cmp基本写法都与sort的相同,当然set,map的cmp可不仅仅是函数了,而是函数对象:
- struct cmp{
- bool operator ()(const int a , const int b)
- {
- return a < b ; // 从小到大,反过来就是从大到小
- }
- };
下面仅仅对set做代码测试:
-
#include <iostream> -
#include <cstring> -
#include <set> -
-
using namespace std ; -
-
struct Person{ -
int age; -
char name[20]; -
Person(int Age , const char Name[]):age(Age){strcpy(name,Name);} -
}; -
struct cmp{ -
bool operator ()(const Person a , const Person b) -
{ -
return a.age < b.age ; // 从小到大 ; -
} -
}; -
-
int main() -
{ -
set<Person,cmp> s ; -
Person n1(46,”ggg”); -
Person n2(-16,”fff”); //年龄无负数,只是为了测试代码,下同 -
Person n3(45,”eee”); -
Person n4(-25,”ddd”); -
Person n5(34,”ccc”); -
Person n6(22,”bbb”); -
Person n7(2,”aaa”); -
s.insert(n1); -
s.insert(n2); -
s.insert(n3); -
s.insert(n4); -
s.insert(n5); -
s.insert(n6); -
s.insert(n7); -
set<Person,cmp>::iterator begin = s.begin(); -
set<Person,cmp>::iterator end = s.end(); -
for(set<Person,cmp>::iterator i = begin ; i != end ; ++i) -
{ -
cout<<i->age<<” ”<<i->name<<endl ; -
} -
return 0 ; -
}
测试结果:
好的,废话也说了这么多了,那我们就来个总结吧:
在调用C的库函数qsort时,因为C语言没有明确的定义bool类型,只是笼统的说,零为假,任何非零都是真,而qsort的cmp函数是返回int的,通过<和>比较两个数据只能返回非零值(真)或零(假),具体返回多少,得看编译器,据我猜测qsort内部是根据返回的正或负或0来判断两个数之间的大小或等于关系的,这时用<或>就不能正常排序了。
而在C++中,已经定义了bool类型,而且sort的cmp函数返回的是bool类型的,说明sort的判断方式与qsort不同的,需要返回一个布尔值,来判断两个数之间的关系的。
所以在C++中应该使用sort中t的cmp函数写法;
这篇文章纯属交流,有错请望指出!
ps:以上代码均在Dev C++ 5.4.1中实验。
- 浅谈C/C++排序函数中cmp()比较函数的写法(qsort sort函数)
- 浅谈C/C++排序函数中cmp()比较函数的写法
- 浅谈C/C++排序函数中cmp()比较函数的写法
- 浅谈C/C++排序函数中cmp()比较函数的写法
- [c/c++]qsort中cmp函数写法
- 【C/C++】C语言中qsort的cmp函数写法汇总
- 排序函数中比较函数cmp的理解
- 有关排序函数cmp写法
- c++ 中 sort 与 c 的去sort cmp 比较函数 书写区别,待总结
- C++<algorithm>中sort的比较函数写法
- C++<algorithm>中sort的比较函数写法
- C++<algorithm>中sort的比较函数写法
- qsort()中cmp函数写法
- JAVA中sort函数的 自定义排序 cmp函数的写法 (基础向)
- C++排序函数中cmp()比较函数详解
- 谈谈C/C++中的排序函数的比较函数的写法。切忌不要走火入魔。
- C Tips: 比较函数 int(*cmp)(const void *, const void *)
- qsort中cmp函数写法汇总
- Java Web中的Action、Dao、Service、Model
- 封装OKHttp,工具类
- SRS 代码分析【DVR录像实现】
- 为什么要用枚举实现Singleton--java
- linux_安装CDN
- 浅谈C/C++排序函数中cmp()比较函数的写法
- from表单+地区
- eclipse打点没提示原因
- 菜鸟备忘录[CSS3]——媒体查询使用方法@media
- CodeForces 830C Bamboo Partition
- SpringAOP整合Hibernate并使用事务(模拟买书的过程)
- kuangbin专题五 并查集 POJ2236-Wireless Network
- UE4 C++创建删除文件夹(对本地文件夹进行操作)
- shell