c语言cmp函数含义,【C艹】关于sort用法之重构cmp(comp)函数的笔记

众所周知,balabalabalabala············。

所以掌握sort函数(库文件:)的用法还是很有必要的。

一般选手只会简单地用用sort排一排数组之类,但是一旦掌握了sort的精髓cmp函数(也有叫comp,名字不重要)的重构,sort函数也可以玩得出神入化。

这里只是不全面地记录下了在切题的过程中遇到的重构cmp的应用,仅供参考:

一、cmp函数的原理探究

研究sort的底层代码就会知道,sort函数非常强大,内部结合了多种排序算法以达到相对稳定的高效。但是不管排序的策略如何,其中都用一个“比较”的步骤。而cmp函数(全称大概代表了单词compare,表示“比较”的意思)便定义了这个比较的标准。

举个栗子:当比较一个数组中a、b(a

怎么把我们对cmp函数的重构应用到sort函数里面呢?

从下面可以看出sort模板有三个参数:

voidsort ( RandomAccessIterator first, RandomAccessIterator last );void sort (RandomAccessIterator first, RandomAccessIterator last, Compare comp);//排序区间为[first,last)//注: 随机迭代器,能用此算法的容器是支持随机访问的容器:vector, deque, string。不支持链表一类的排序。

然后我们转到sort的定义找到默认的comp:

//TEMPLATE FUNCTION sort

templateinlinevoidsort(_RanIt _First, _RanIt _Last)

{//order [_First,

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值