zoukankan      html  css  js  c++  java
  • lower_bound和upper_bound

    原理

    运用二分的方法进行查找,可以用于逆序对等题目。template出门右转百度。

    用法

    • lower_bound( begin,end,num):从数组的begin位置到end-1位置二分查找第一个大于或等于num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。
    • upper_bound( begin,end,num):从数组的begin位置到end-1位置二分查找第一个       大于   num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。

    我们可以使用<functional>里的greater改变lower_bound和upper_bound的排序办法来查找。

    • lower_bound( begin,end,num,greater(type)):从数组的begin位置到end-1位置二分查找第一个小于或等于num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。
    • upper_bound( begin,end,num,greater(type)):从数组的begin位置到end-1位置二分查找第一个       小于   num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。

    总之lower_bound会带上这个数字本身啦~

  • 相关阅读:
    动态页面技术----EL技术、JSTL技术,javaEE的开发模式
    动态页面技术----JSP技术
    会话技术Cookie&Session
    HttpServletRequest
    设计模式和抽象类、方法
    类的继承
    类与对象
    面向对象和面向过程的区别
    PHP-错误处理
    PHP-文件加载
  • 原文地址:https://www.cnblogs.com/BrotherHood/p/12929460.html
Copyright © 2011-2022 走看看