greater<int>()和less<int>()的使用

转自:http://blog.csdn.net/chijianxingfeng/article/details/8886399


greater和less

greater和less是头文件<xfunctional>中定义的两个结构。下面看它们 的定义,greater和less都重载了操作符()。

[cpp]  view plain  copy
  1.     // TEMPLATE STRUCT greater  
  2. emplate<class _Ty>  
  3. struct greater  
  4.     : public binary_function<_Ty, _Ty, bool>  
  5. {   // functor for operator>  
  6. bool operator()(const _Ty& _Left, const _Ty& _Right) const  
  7.     {   // apply operator> to operands  
  8.     return (_Left > _Right);  
  9.     }  
  10. };  
  11.   
  12.     // TEMPLATE STRUCT less  
  13. emplate<class _Ty>  
  14. struct less  
  15.     : public binary_function<_Ty, _Ty, bool>  
  16. {   // functor for operator<  
  17. bool operator()(const _Ty& _Left, const _Ty& _Right) const  
  18.     {   // apply operator< to operands  
  19.     return (_Left < _Right);  
  20.     }  
  21. };  

在sort()函数中使用greater<int>()和less<int>(),

[cpp]  view plain  copy
  1. #include<iostream>  
  2. #include<algorithm>//因为用了sort()函数  
  3. #include<functional>//因为用了greater<int>()  
  4. using namespace std;  
  5.   
  6. void main()  
  7. {  
  8.     int a[]={3,1,4,2,5};  
  9.     int i;  
  10.     int len=sizeof(a)/sizeof(int);//这里切记要除以sizeof(int)!  
  11.   
  12.     sort(a ,a + len, greater<int>());//内置类型的由大到小排序  
  13.     for(i=0;i<len;i++)  
  14.         cout<<a[i]<<" ";  
  15.     cout<<"\n";  
  16.     sort(a, a + len, less<int>());        //内置类型的由小到大排序  
  17.     for(i=0;i<len;i++)  
  18.         cout<<a[i]<<" ";  
  19. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值