码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C++ sort函数自定义cmp函数中参数带&符号


    今天在刷leetcode每日一题的时候,用到了sort函数且需要自定义cmp排序规则。然后发现答案几乎是前篇一律:cmp函数中参数都带有&,并且使用const关键字修饰。
    这不禁让我产生了疑惑,并搜集了网上大量资料加上自己的实践,与君共享。

    对于cmp函数,笔者建议前面最好都加上static修饰,以下雷同
    对于初学者,使用cmp时,一般是这样的

    static bool cmp(int a, int b){
        return a>b;
    }
    
    int a[10];
    sort(a,a+10,cmp);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    但是在刷leetcode的时候,更多的却是

    static bool cmp(const int &a, const int &b){
        return a>b;
    }
     
    int a[10];
    sort(a,a+10,cmp);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    省流!!!看这里

    先说结论:第二种方法const int &a是最科学的

    实际上,&在学指针的时候,我们叫他取地址符,但是它的作用有两个

    1. 取地址
    2. 表示值引用

    接下来,我们来说明第二点值引用的样例,
    我们希望手动实现一个swap函数

    void swap(int a,int b){
        int temp = a;
        a = b;
        b = temp;
    }
    
    int a = 5, b = 10;
    swap(a,b);
    cout<<a<<" "<<b;  //5 10
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    这个反例大家应该很熟悉,这里的swap函数并没有起到作用,因为int这种写法是值传递,函数将自动产生临时变量用于复制该参数,仅仅是复制这个值,然后临时变量在计算机的内存里新开辟了一个存储地址,原理存储地址存的ab值没有改变。
    我们再看

    void swap(int &a,int &b){
        int temp = a;
        a = b;
        b = temp;
    }
    
    int a = 5, b = 10;
    swap(a,b);
    cout<<a<<" "<<b;  //10 5
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    这里swap函数成功交换了ab的值,因为int &这里是引用传递,不会产生临时变量,在计算机里他们是指向同一片存储地址,在用户视角来看是仅借用一下参数的别名而已。

    好!重点来了,那么这里有人就想问了,那这个跟我cmp函数使不使用&有什么关系呢?继续往下看。
    刚才上面已经说了,使用int进行值传递的时候,由于函数将自动产生临时变量用于复制该参数,效率较低。(值传递需要调用内存用来重新开辟临时的存储空间用来存放临时变量)
    而使用int &进行引用传递的时候,借用一下参数的别名而已,不需要产生临时对象,效率较高。(不用开辟新的临时空间用来存放变量,省去了将实参拷贝给形参的过程)。
    但是还有一点就是,“引用传递”有可能改变参数,我们可以加上const修饰,防止直接更改引用变量。

    因此这样的话,我们在自定义cmp函数时,使用引用传递要比值传递执行效率快很多。

  • 相关阅读:
    MYSQL第五章节有关约束操作详解(附代码,例题详解)这一篇就够了
    经过CNN、LSTM训练、预测,数据集的数据为什么会被打乱?以及基于pytorch框架代码实现打乱后的恢复
    写给开发人员的实用密码学(五)—— 密钥交换 DHKE 与完美前向保密 PFS
    wayland(xdg_wm_base) + egl + opengles 光照模型实例(十五)
    上海亚商投顾:沪指震荡调整 转基因概念股逆势大涨
    虹科分享|如何保障医疗数据安全?移动目标防御技术给你满意的答案
    KT6368A蓝牙的认证问题_FCC和BQB_CE_KC认证或者其它说明
    线性表应用(非递减合并、分解链表、删除线性表)
    数据 | MongoDB Compass 连接远程数据库及 Nest.js 连接 MongoDB
    有意思的鼠标指针交互探究
  • 原文地址:https://blog.csdn.net/weixin_45774972/article/details/133779716
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号