lower_bound当target存在时, 返回它出现的第一个位置,如果不存在,则返回这样一个下标i:在此处插入target后,序列仍然有序。

代码如下:

int lower_bound(int* nums, int numsSize, int target) {
//注意left和right的初始值必须是left = 0, right = numsSzie, 因为插入的位置可能是[0,numsSize]
int left = 0;
int right = numsSize;
int mid;
while (left < right)
{
mid = left + (right - left) / 2;
if (nums[mid] >= target)
right = mid;
else
left = mid + 1;
} return left;
}

尽管查找区间是[0, numsSize),但返回值区间却是[0, numsSize]。因此right的初始值必须为numsSize,而不是numsSize - 1。

当nums[mid] == target时,至少已经找到了一个,而左边可能还有,因此区间变为[left, mid];

当nums[mid] > target时,所求位置不可能在后面,但有可能是mid,因此区间变为[left, mid];

当nums[mid] < target时,mid和前面都不可行,因此所求区间为[mid+1, right]。

合并一下,当nums[mid] >= target时,所求区间为[left, mid];当nums[mid] < target时,所求区间为[mid + 1, right]。

类似地,可以写一个upper_bound程序,当target存在时, 返回它出现的最后一个位置的后面一个位置,如果不存在,则返回这样一个下标i:在此处插入target后,序列仍然有序。

int upper_bound(int* nums, int numsSize, int target) {
//注意left和right的初始值必须是left = 0, right = numsSzie, 因为插入的位置可能是[0,numsSize]
int left = 0;
int right = numsSize;
int mid;
while (left < right)
{
mid = left + (right - left) / 2;
if (nums[mid] <= target)
left = mid + 1;
else
right = mid;
}
return left;
}

最新文章

  1. 深入理解计算机系统(4.1)---X86的孪生兄弟,Y86指令体系结构
  2. 记一次SQLServer数据库误删数据找回
  3. Sublime Text 前端插件推荐
  4. bzoj3047: Freda的传呼机 &amp;&amp; 2125: 最短路
  5. 《Java程序员面试笔试宝典》之字符串创建与存储的机制是什么
  6. GIT的下载、安装、与使用
  7. ARC引用计数
  8. spring mvc中,直接注入的HttpServletRequst是否安全呢?
  9. 201521123112《Java程序设计》第13周学习总结
  10. HDU [P2819] swap
  11. C++关于Union使用的部分总结
  12. Django rest framework(6)----序列化(2)
  13. ios dispatch_async使用
  14. TCP/IP协议 模型
  15. 解决 ionic 中的 CORS(跨域)
  16. Visual Studio 2017 版本 15.5.5
  17. Inferred type &#39;S&#39; for type parameter &#39;S&#39; is not within its bound;
  18. python中集合及运算
  19. Barricade HDU - 5889(最短路+最小割)
  20. Jenkins-在节点上执行copy命令,将节点机上的文件拷贝到映射的网络驱动盘中报错,访问被拒绝 找不到指定驱动器

热门文章

  1. ASP.NET Core分布式日志系统ELK实战演练
  2. 多任务学习(MTL)在转化率预估上的应用
  3. Kubernetes工作流程--&lt;1&gt;
  4. vuejs集成echarts的一些问题
  5. OO_Unit3总结
  6. day-6 xctf-hello_pwn
  7. 2021S软件工程——结对项目第三阶段
  8. composer 使用提示
  9. 【Http】Http请求的流程
  10. 关于Hexo博客NEXT主题(Gmini)站点图标不显示,显示错误的解决办法