iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >你知道如何自定义sort函数中的比较函数
  • 431
分享到

你知道如何自定义sort函数中的比较函数

2024-04-02 19:04:59 431人浏览 八月长安
摘要

目录如何自定义sort函数中的比较函数题目描述思路回到最初的问题中总结起来就是sort()基本用法对int类型数组排序对char类型数组排序(同int类型)对double类型数组排序

如何自定义sort函数中的比较函数

在做剑指offer时,有一道题:

题目描述

输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。

思路

自定义比较器,若a+b>b+a则a>b,即”3”+”23”>”23”+”3”则3>23,并且我们希望在排序的时候将23排在3的前面,也就是升序排列。


class Solution {
public:
    static bool compare(const string& s1, const string& s2)
    {
        string ab = s1 + s2;
        string ba = s2 + s1;
        return ab < ba; //升序排列。如改为ab > ba, 则为降序排列
    }
    string PrintMinNumber(vector<int> numbers) 
    {
        string result;
        if(numbers.size() <= 0) return result;
        vector<string> num2str;
        for(int i = 0; i < numbers.size(); i++)
        {
            stringstream ss;
            ss << numbers[i];
            string s = ss.str();
            num2str.push_back(s);
        }
        sort(num2str.begin(), num2str.end(), compare);
        for(int i = 0; i < num2str.size(); i++)
        {
            result.append(num2str[i]);
        }
        return result;
    }
};

这道题的解法中用到了自定义比较器。也就是自定义了campare函数。

但是为什么当ab<ba的时候就是升序排列了呢?十分不解,在网上搜了好多资料,最后看到了c++的技术文档,醍醐灌顶!!!强烈推荐直接看技术文档,比在网上查来查去明白的更快!

Http://www.cplusplus.com/reference/alGorithm/sort/

这里写图片描述


// sort algorithm example
#include <iOStream>     // std::cout
#include <algorithm>    // std::sort
#include <vector>       // std::vector
bool myfunction (int i,int j) { return (i<j); }
struct myclass {
  bool operator() (int i,int j) { return (i<j);}
} myobject;
int main () {
  int myints[] = {32,71,12,45,26,80,53,33};
  std::vector<int> myvector (myints, myints+8);               // 32 71 12 45 26 80 53 33
  // using default comparison (operator <):
  std::sort (myvector.begin(), myvector.begin()+4);           //(12 32 45 71)26 80 53 33
  // using function as comp
  std::sort (myvector.begin()+4, myvector.end(), myfunction); // 12 32 45 71(26 33 53 80)
  // using object as comp
  std::sort (myvector.begin(), myvector.end(), myobject);     //(12 26 32 33 45 53 71 80)
  // print out content:
  std::cout << "myvector contains:";
  for (std::vector<int>::iterator it=myvector.begin(); it!=myvector.end(); ++it)
    std::cout << ' ' << *it;
  std::cout << '\n';
  return 0;
}

可以看到comp的定义:comp函数返回一个bool类型的值,这个值表示了在严格弱排序中(可以理解为升序排序)第一参数是否位于第二个参数之前。

也就是说如果comp返回true,则第一个参数小于第二个参数,sort根据compare的返回值将第一个参数排在第二个参数之前。

如果comp返回false,则第一个参数大于第二个参数,sort根据compare的返回值将第一个参数排在第二个参数之后。

  • 传入A,B,定义bool myfunction (int i,int j) { return (i<j); },作为comp函数,则排列AB。
  • 传入BA,则排列AB。

可以看出是升序排列的。(sort函数默认的comp函数也是默认升序的)

而如果我们定义bool myfunction (int i,int j) { return (i>j); },作为comp函数,

  • 传入AB,返回false,则排列为BA,
  • 传入BA,返回true,排列为BA。

是降序排列的。

回到最初的问题中


    static bool compare(const string& s1, const string& s2)
    {
        string ab = s1 + s2;
        string ba = s2 + s1;
        return ab < ba; //升序排列。如改为ab > ba, 则为降序排列
    }

我们可以看出 如果s1=”3”, s2=”23”

ab = “323”;

ba = “233”;

事实上ab>ba,所以comp会返回false,sort根据compare返回的false将s2排列在s1之前,也就是排列成”23”,”3”这也就是我们想要的结果。

总结起来就是

sort函数根据comp函数的返回值,对comp函数的两个参数排序。

如果comp返回true,排序为“参数1”“参数2”,否则排序为“参数2”“参数1”。

  • 想要升序排列,则return parameter1<parameter2
  • 想要降序排列,则return parameter1>parameter2

sort()基本用法

做ACM题的时候,排序是一种经常要用到的操作。如果每次都自己写个冒泡之类的O(n^2)排序,不但程序容易超时,而且浪费宝贵的比赛时间,还很有可能写错。STL里面有个sort函数,可以直接对数组排序,复杂度为n*log2(n)。使用这个函数,需要包含头文件。

这个函数可以传两个参数或三个参数。第一个参数是要排序的区间首地址,第二个参数是区间尾地址的下一地址。也就是说,排序的区间是[a,b)。简单来说,有一个数组int a[100],要对从a[0]到a[99]的元素进行排序,只要写sort(a,a+100)就行了,默认的排序方式是升序。

拿我出的“AC的策略”这题来说,需要对数组t的第0到len-1的元素排序,就写sort(t,t+len);

对向量v排序也差不多,sort(v.begin(),v.end());

排序的数据类型不局限于整数,只要是定义了小于运算的类型都可以,比如字符串类string。

如果是没有定义小于运算的数据类型,或者想改变排序的顺序,就要用到第三参数——比较函数。比较函数是一个自己定义的函数,返回值是bool型,它规定了什么样的关系才是“小于”。想把刚才的整数数组按降序排列,可以先定义一个比较函数cmp


bool cmp(int a,int b)
{
return a>b;
}

排序的时候就写sort(a,a+100,cmp);

假设自己定义了一个结构体node


struct node{
int a;
int b;
double c;
}

有一个node类型的数组node arr[100],想对它进行排序:先按a值升序排列,如果a值相同,再按b值降序排列,如果b还相同,就按c降序排列。就可以写这样一个比较函数:

以下是代码片段:


bool cmp(node x,node y)
{
if(x.a!=y.a) return x.a
if(x.b!=y.b) return x.b>y.b;
return return x.c>y.c;
} 

排序时写sort(arr,a+100,cmp);


qsort(s[0],n,sizeof(s[0]),cmp);
int cmp(const void *a,const void *b)
{
return *(int *)a-*(int *)b;
}

对int类型数组排序


int num[100];
Sample:
int cmp ( const void *a , const void *b )
{
return *(int *)a - *(int *)b;
}
qsort(num,100,sizeof(num[0]),cmp);

对char类型数组排序(同int类型)


char Word[100];
Sample:
int cmp( const void *a , const void *b )
{
return *(char *)a - *(int *)b;
}
qsort(word,100,sizeof(word[0]),cmp);

对double类型数组排序(特别要注意)


double in[100];
int cmp( const void *a , const void *b )
{
return *(double *)a > *(double *)b ? 1 : -1;
}
qsort(in,100,sizeof(in[0]),cmp);

对结构体一级排序


struct In
{
double data;
int other;
}s[100]
//按照data的值从小到大将结构体排序,关于结构体内的排序关键数据data的类型可以很多种,参考上面的例子写
int cmp( const void *a ,const void *b)
{
return ((In *)a)->data - ((In *)b)->data ;
}
qsort(s,100,sizeof(s[0]),cmp);

对结构体


struct In
{
int x;
int y;
}s[100];
//按照x从小到大排序,当x相等时按照y从大到小排序
int cmp( const void *a , const void *b )
{
struct In *c = (In *)a;
struct In *d = (In *)b;
if(c->x != d->x) return c->x - d->x;
else return d->y - c->y;
}
qsort(s,100,sizeof(s[0]),cmp);

对字符串进行排序


struct In
{
int data;
char str[100];
}s[100];
//按照结构体中字符串str的字典顺序排序
int cmp ( const void *a , const void *b )
{
return strcmp( ((In *)a)->str , ((In *)b)->str );
}
qsort(s,100,sizeof(s[0]),cmp);

计算几何中求凸包的cmp


int cmp(const void *a,const void *b) //重点cmp函数,把除了1点外的所有点,旋转角度排序
{
struct point *c=(point *)a;
struct point *d=(point *)b;
if( calc(*c,*d,p[1]) < 0) return 1;
else if( !calc(*c,*d,p[1]) && dis(c->x,c->y,p[1].x,p[1].y) < dis(d->x,d->y,p[1].x,p[1].y)) //如果在一条直线上,则把远的放在前面
return 1;
else return -1;
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: 你知道如何自定义sort函数中的比较函数

本文链接: https://www.lsjlt.com/news/160435.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 你知道如何自定义sort函数中的比较函数
    目录如何自定义sort函数中的比较函数题目描述思路回到最初的问题中总结起来就是sort()基本用法对int类型数组排序对char类型数组排序(同int类型)对double类型数组排序...
    99+
    2022-11-12
  • Golang函数的内建函数和自定义函数的优劣比较
    Golang是一门非常流行的编程语言,其拥有非常强大的函数库。在Golang中,函数被视为一等公民,这意味着Golang的函数可以像变量一样被传递、复制以及重载。此外,Golang还提供了内建函数和自定义函数两种类型。在本文中,我们将探讨G...
    99+
    2023-05-16
    自定义函数 Golang函数 内建函数
  • Android自定义view 你所需要知道的基本函数总结
    Android自定义view 你所需要知道的基本函数 首先 往Canvas上面draw需要一个Paint。 画笔常用的函数有哪些呢。由于木有调试环境,函数基本上默写,有错请评论...
    99+
    2022-06-06
    view 函数 Android
  • JavaScript中如何自定义函数
    JavaScript中如何自定义函数,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 js自定义函数的写法:1、“f...
    99+
    2022-10-19
  • sqlserver中如何自定义函数
    这期内容当中小编将会给大家带来有关sqlserver中如何自定义函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。“自定义函数”是我们平常的说法,而“用户定义的函数”是 ...
    99+
    2022-10-18
  • Python中如何自定义函数
    目录Python自定义函数1 自定义函数的语法2 自定义函数的实现3 自定义函数的调用Python自定义函数基础概念一、函数定义语法二、函数文档字符串三、函数定义规则五、函数调用六、...
    99+
    2023-01-04
    Python自定义函数 Python函数 如何自定义函数
  • linux中shell如何自定义函数
    小编给大家分享一下linux中shell如何自定义函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、定义shell函数(define function)语法:...
    99+
    2023-06-09
  • Sql Server中如何自定义函数
    今天就跟大家聊聊有关Sql Server中如何自定义函数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、判断字段值是否有中文--SQL ...
    99+
    2022-10-18
  • 如何在PHP中自定义函数
    在PHP中,函数是一组可重复使用的代码块,它们通过一个名称来标识。PHP支持大量现成的函数,如array_push、explode等,但有时候你需要编写自己的函数以实现特定的功能或提高代码复用性。在这篇文章中,我将介绍如何在PHP中自定义函...
    99+
    2023-05-18
    函数编程 自定义函数 PHP编程
  • 如何在shell中自定义函数
    这篇文章给大家介绍如何在shell中自定义函数,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一,调用函数必须在定义函数的后,不然会报错的funfun (){ echo "aaaa...
    99+
    2023-06-09
  • 你知道如何在 Spring 中使用 ASP 函数吗?
    Spring 是一个流行的 Java 开发框架,它提供了各种功能和工具来简化开发过程。其中,ASP 函数是 Spring 中一个非常有用的功能,它可以帮助我们快速地实现一些常见的数据操作。 ASP 函数是 Spring 框架中的一个核心功能...
    99+
    2023-09-05
    函数 spring git
  • Java自然语言处理中的同步函数,你知道吗?
    随着人工智能技术的发展,自然语言处理(NLP)已经成为了人工智能领域中的一个重要方向。在NLP中,同步函数是一个十分重要的概念。本文将介绍Java自然语言处理中的同步函数,并演示如何在Java中使用同步函数进行自然语言处理。 什么是同步函...
    99+
    2023-10-29
    自然语言处理 同步 函数
  • 你知道如何在Go中打包接口函数吗?
    当我们在使用 Go 编写代码时,经常会使用接口函数。接口函数可以使我们的代码更加灵活,能够适应不同的场景和需求。但是,在编写接口函数时,我们可能会遇到一个问题:如何在 Go 中打包接口函数呢? 在本文中,我们将会讨论这个问题。我们将会介绍如...
    99+
    2023-09-20
    打包 接口 函数
  • 你是否知道如何在 Django 中使用 Go 函数?
    Django 是一个流行的 Python Web 框架,它提供了许多有用的工具和库来帮助开发人员快速构建高质量的 Web 应用程序。但是,有时候我们需要使用其他语言编写的功能来扩展 Django 的能力。本文将向您介绍如何在 Django ...
    99+
    2023-07-09
    函数 linux django
  • 你知道PHP中NPM函数如何处理响应吗?
    PHP中的NPM函数是一种非常强大的工具,可以帮助我们处理HTTP请求和响应。当我们发送一个HTTP请求时,服务器会返回一个HTTP响应。NPM函数可以帮助我们处理这些响应,从而使我们的应用程序更加强大和灵活。在本文中,我们将深入研究PHP...
    99+
    2023-09-01
    npm 函数 响应
  • 你知道如何使用 Go 在 Spring 中索引函数吗?
    在现代软件开发中,使用多种编程语言的组合来构建完整的系统已经成为了一种趋势。如果你是一个 Java 开发者,你可能会想使用 Go 来编写一些高性能的组件。在本文中,我们将讨论如何在 Spring 中使用 Go 索引函数。 在 Spring ...
    99+
    2023-10-11
    索引 spring 函数
  • 你是否知道如何在Django Shell中使用Python函数?
    Django Shell是一个非常有用的工具,可以让你在命令行中与Django应用程序进行交互。它允许你执行一些Python代码,以便在Django中进行测试或者进行一些有用的操作。在本文中,我们将介绍如何在Django Shell中使用...
    99+
    2023-09-30
    函数 django shell
  • 你知道如何在Spring框架中使用Java函数吗?
    Spring框架是目前应用较广泛的Java开发框架之一。它提供了许多方便的功能和工具,使得Java开发变得更加高效和便捷。在Spring框架中,我们可以使用Java函数来实现一些常见的操作,如数据处理、业务逻辑处理等。本文将介绍如何在Spr...
    99+
    2023-09-16
    函数 spring 框架
  • 你知道如何使用 ASP 函数来优化你的网站吗?
    当今互联网时代,网站的访问速度是非常重要的。ASP 函数是一种用于优化网站的非常重要的工具。在本文中,我们将介绍如何使用 ASP 函数来优化你的网站。 一、什么是 ASP 函数? ASP 函数是一种能够执行特定任务的代码模块。它们可以接收输...
    99+
    2023-08-30
    函数 http 关键字
  • 你是否知道如何在ASP和Apache中使用大数据函数?
    随着互联网时代的到来,数据已成为人们获取信息、做出决策的重要资源,而大数据技术的出现,则使得数据的处理和分析更加高效和精确。而在ASP和Apache中,我们同样可以利用大数据函数来更好地处理数据。本文将介绍ASP和Apache中常用的大数据...
    99+
    2023-07-22
    apache 大数据 函数
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作