当前位置: 首页 > article >正文

排序算法之自定义排序函数的含义

我们经常碰到stl容器或者一些排序算法需要用户自定义实现排序规则,为什么要用户自定义排序规则函数呢?请考虑如下场景:

std::vector<int> nums = {1, 3, 2, 5, 4};

// 升序排序(默认)
std::sort(nums.begin(), nums.end(), std::less<int>());
// 或简写为
std::sort(nums.begin(), nums.end());  // 默认使用 operator<

// 降序排序
std::sort(nums.begin(), nums.end(), std::greater<int>());

上面的例子会使用默认的比较函数,用户只需要指定升序还是降序就可以了。但是数据类型不一定都是整型,很有可能是用户自定的类,请看下面的例子:

class Myclass
{
    private:
        std::string name;
        int age;
}

上面的的类型中包含了2个变量,这种情况下应该如何进行排序呢?sort方法肯定没有办法实现这种用户自定义的类型不用成员的排序,那应该怎么办呢?于是sort函数提供了一种方式,即用户自己实现一个函数或者函数对象,这个函数的形式如下:

bool func(T a, T b);
//返回值为布尔型,该函数有两个输入参数,参数的类型都是要进行排序的数据类型
  1. 输入参数a:数据类型为T,这里的T表示的是排序的数据类型,比如上面的例子是类型就是Myclass
  2. 输入参数b:数据类型为T,这里的T表示的是排序的数据类型,比如上面的例子是类型就是Myclass
  3. 返回值:布尔值类型,true的含义是a在b的前面;false的含义是a在b的后面。注意这个函数的含义是a与b比较,若为true,则第一个参数a在第二个参数b前面;若为false,则相反


http://www.kler.cn/a/548357.html

相关文章:

  • 闲鱼IP属地是通过电话号码吗?
  • Hami项目开发笔记
  • 使用grafana v11 建立k线(蜡烛图)仪表板
  • 为什么innodb支持事务
  • tkinter-TinUI-xml实战(12)应用组启动器
  • vue-model如何自定义指令,及批量注册自定义指令
  • 【CS.SE】优化 Redis 商户号池分配设计:高并发与内存管理
  • 播客自动化实操:用Make自动制作每日新闻播客
  • Vue 入门到实战 十
  • SpringCloud框架下的注册中心比较:Eureka与Consul的实战解析
  • 深入了解 Oracle 正则表达式
  • vue字符串的常用方法,截取字符串,获取字符串长度,检索字符串
  • 【ESP32 IDF】ESP32 linux 环境搭建
  • 坑多多之AC8257 i2c1 rtc-pcf8563
  • C#学习之数据转换
  • 【Git】三、远程管理
  • 蓝桥杯 Java B 组之总结与模拟题练习
  • C++STL容器之map的使用及复现
  • windows10本地的JMeter+Influxdb+Grafana压测性能测试,【亲测,避坑】
  • 深入解析Jenkins——持续集成与持续交付的中坚力量