自定义lower_bound二分查找函数的比较方式(网易2019秋招笔试题1)

第一种方式,为参与比较的元素类型重载<

第二种方式,最后增加一个仿函数临时对象参数

第三种方式,最后增加一个函数指针参数

特别需要注意的就是,传入的要查找的参数类型也一定是和容器中的数据类型一样,而不是和具体比较的时候用的基本类型一样,比如下面的例子,不能直接将int型的qi传入查找,而是应该构建一个临时对象heaps(0,qi),再去和其他的容器中元素进行比较。

/*
问题:
将n堆苹果,从左往右摆放,并对苹果和堆都从1开始顺序编号。
现在任意喊一个苹果编号,问你是在第几堆。
输入:一个堆数n,然后一行是n个数表示每堆苹果的数量。
再输入一个数m表示有几个苹果要找,然后是m个苹果编号。
输出:m个苹果编号对应的是在第几堆。


分析:就是一个二分法的典型应用。首先要对堆用一个id记录下来,然后要在堆中记录这个堆表示的边界值。
将各个苹果堆插入到一个vector中
然后根据堆类中的边界值对vector排序,然后再对有序序列用lower_bound二分查找函数进行查找,
返回的就是大于等于要查找值的边界值,对应输出该堆的id,就是我们要的结果。
*/

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
class heaps
{
public:
    int id;
    int num;
    heaps(int i, int j) :id(i), num(j){};
    //方式一:重载小于号的形式,注意只能有一个参数,<号分左值和右值
    
    bool operator<(const heaps &h2)
    {
        return num < h2.num;
    }
    

};
//仿函数形式的比较函数,使用的时候传入临时对象comp()
class comp
{
public:
    bool operator()(const heaps &a, const heaps &b)
    {
        return a.num < b.num;
    }
};


//纯比较函数,使用的时候传入函数名就行
bool comp_func(const heaps &a, const heaps &b)
{
return a.num < b.num;
}


int main()
{
    int n;
    cin >> n;

    vector<heaps> v_apps;
    int a1;
    cin >> a1;
    v_apps.push_back(heaps(1, a1));

    for (int i = 1; i < n; i++)
    {
        int ai;
        cin >> ai;
        int aa = ai + v_apps[i - 1].num;
        v_apps.push_back(heaps(i + 1, aa));
    }

    int m;
    cin >> m;
    for (int i = 0; i < m; i++)
    {
        int qi;
        cin >> qi;
        //第一种用法,特别注意,不能直接用qi作为参数,而是应该构造一个heaps类的临时对象,才能比较
        auto pos = lower_bound(v_apps.begin(), v_apps.end(), heaps(0, qi));
        //第二种用法
        //auto pos = lower_bound(v_apps.begin(), v_apps.end(), heaps(0, qi), comp());
        //第三种用法
        //auto pos = lower_bound(v_apps.begin(), v_apps.end(), heaps(0, qi), comp_func);
        cout << (*pos).id << endl;
    }

    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容

  • 前言 把《C++ Primer》[https://book.douban.com/subject/25708312...
    尤汐Yogy阅读 9,513评论 1 51
  • 〇、前言 本文共108张图,流量党请慎重! 历时1个半月,我把自己学习Python基础知识的框架详细梳理了一遍。 ...
    Raxxie阅读 18,935评论 17 410
  • 前段时间网络上报出一医院为抢救重病患者争分夺秒,把患者衣服剪了,之后患者家属要求索赔的情况,虽然大家都力挺医生,为...
    十三号仓库阅读 297评论 4 6
  • dns查询过程解析 DNS查询模式有递归查询和迭代查询,他们的区别如下: (1)递归查询 递归查询是一种DNS 服...
    think_lonely阅读 803评论 0 1
  • 在绝对的实力差异面前,技巧只是自娱自乐和自我消耗罢了。 下面还是结合思维导图,分成基本思想、科学水平与技术、面壁计...
    陶薰读书阅读 2,313评论 2 4