C_and_CPP 板


LINE

开发平台(Platform): (Ex: Win10, Linux, ...) Win10 编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出) G++ 额外使用到的函数库(Library Used): (Ex: OpenGL, ...) #include <vector> #include <algorithm> 问题(Question): 以下程式 建立一个struct comInterval 其中Interval是额外宣告的structure 利用<algorithm>的sort做排序 我比较不明白的是 sort(intervals.begin(),intervals.end(),compInterval()); 送入第三个参数的方法 请问这个方法是运算子多载吗?? 有没有正确的术语呢 不知道该从何查起 喂入的资料(Input):预期的正确结果(Expected Output):错误结果(Wrong Output):程式码(Code):(请善用置底文网页, 记得排版) class Solution { public: struct compInterval { bool operator()(const Interval &a, const Interval &b) const { return a.start<b.start; } }; vector<Interval> merge(vector<Interval> &intervals) { sort(intervals.begin(),intervals.end(),compInterval()); vector<Interval> ret; for(int i=0; i<intervals.size(); i++) { if(ret.empty() || ret.back().end < intervals[i].start) // no overlap ret.push_back(intervals[i]); else // overlap ret.back().end = max(ret.back().end, intervals[i].end); } return ret; } }; 补充说明(Supplement): --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 1.163.46.117
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1516158062.A.A42.html
1F:→ loveflames: http://www.cplusplus.com/reference/algorithm/sort/ 01/17 11:02
2F:→ yamakazi: 这个网页我有查到 但我想知道实作这个方法的名字叫做?? 01/17 11:04
3F:→ loveflames: 第三个参数是比较函数 01/17 11:07
4F:→ loveflames: 随便取,但行为不能违反<的含意 01/17 11:07
5F:→ loveflames: compInterval()是临时物件,传入sort内部会以functor 01/17 11:15
6F:→ loveflames: 的形式去呼叫 01/17 11:15
7F:→ loveflames: 实作逻辑在compInterval::operator() 01/17 11:16
8F:→ notBeing: binary predicate 01/17 11:34
9F:推 TitanEric: 不知道算不算function pointer? 01/17 15:00
10F:→ loveflames: 这例子不算 01/17 15:10
11F:→ loveflames: 当然要传也是可以 01/17 15:11
12F:推 LPH66: 这里的概念是这个参数要能够当函式名呼叫 01/17 20:20
13F:→ LPH66: 能这麽做的物件就称做 functor, 实际实作是使用 operator() 01/17 20:21
14F:→ LPH66: 的运算子重载来定义其行为 01/17 20:21
15F:→ LPH66: 那这里在呼叫时也有一个(), 但这个不是 operator () 01/17 20:22
16F:→ LPH66: 而是单纯建立一个物件 (注意 compInterval 是类别名) 01/17 20:22
17F:→ LPH66: 这里的 () 表示建立物件後呼叫其预设建构子 01/17 20:23
18F:→ loveflames: 如果很在意inline,比较函数不要传函数指标 01/18 10:00
19F:→ loveflames: 只能传functor进去 01/18 10:00
20F:推 ak121ka: "function objects" by c+g primer 4/e p.530 01/19 12:37
21F:→ shk9cvu5ye: http://blog.csdn.net/caroline_wendy/article/detail 01/20 03:12
22F:→ shk9cvu5ye: s/15378055 01/20 03:12







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Gossiping站内搜寻

TOP