模板 #2:

int binarySearch(vector<int>& nums, int target){
if(nums.size() == 0)
return -1; int left = 0, right = nums.size();
while(left < right){
// Prevent (left + right) overflow
int mid = left + (right - left) / 2;
if(nums[mid] == target){ return mid; }
else if(nums[mid] < target) { left = mid + 1; }
else { right = mid; }
} // Post-processing:
// End Condition: left == right
if(left != nums.size() && nums[left] == target) return left;
return -1;
}

模板 #2 是二分查找的高级模板。它用于查找需要访问数组中当前索引及其直接右邻居索引的元素或条件。

关键属性


  • 一种实现二分查找的高级方法。
  • 查找条件需要访问元素的直接右邻居。
  • 使用元素的右邻居来确定是否满足条件,并决定是向左还是向右。
  • 保证查找空间在每一步中至少有 2 个元素。
  • 需要进行后处理。 当你剩下 1 个元素时,循环 / 递归结束。 需要评估剩余元素是否符合条件。

区分语法


    • 初始条件:left = 0, right = length
    • 终止:left == right
    • 向左查找:right = mid
    • 向右查找:left = mid+1

最新文章

  1. 谈谈一些有趣的CSS题目(六)-- 全兼容的多列均匀布局问题
  2. Unity3D热更新全书-PageZero
  3. [ZigBee] 3、ZigBee基础实验——GPIO输出控制实验-控制Led亮灭
  4. 深入浅出 - Android系统移植与平台开发(八)- HAL Stub框架分析
  5. 关于java的static语句块
  6. MyBatis学习总结_10_批量操作
  7. 函数buf_page_init_for_read
  8. C# 数据库dataGridView刷新数据和主外键判断
  9. 试用阿里云RDS的MySQL压缩存储引擎TokuDB
  10. Spring 4学习——问题与注意事项(一)
  11. 性能优化之reflow和repaint
  12. python3[爬虫实战] 使用selenium,xpath爬取京东手机
  13. 小游戏canvas直接操作ImgaeData时的几个优化点
  14. 运行python脚本后台执行
  15. springmvc 简单框架
  16. 高并发第二弹:并发概念及内存模型(JMM)
  17. java===java基础学习(2)---运算符,三元操作符,数学函数
  18. 可以避免的10大IT面试误区
  19. mysql--外键(froeign key)-----------MySQL外键使用详解
  20. Android学习笔记_44_apk安装、反编译及防治反编译

热门文章

  1. 懒松鼠Flink-Boot(Flink+Spring):一款将Flink与Spring生态完美融合的脚手架工程
  2. 【NOI2018】你的名字(SAM &amp; 线段树合并)
  3. 笔记-Recursive Queries
  4. mysql 迁移数据库到 oracle (sql注意问题)
  5. Office Word文件批量生成软件
  6. Jmeter(5)JSON提取器
  7. ORACLE 10g、11g批量刷新用户密码
  8. AWT10-位图
  9. Service Cloud 零基础(二)Knowledge浅谈
  10. Python 设计模式——单例模式