cv_gordon

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: :: :: 管理 ::

题目:

在排序数组中查找元素(包含重复元素)的第一个和最后一个位置。

 

二分法的思想非常简单,然而其中的实现细节非常繁琐,容易出错。本推文非常详细地介绍二分法的实现细节。

总结几点注意事项:

  1. 初始上、下界的取值;
  2. 判断语句不要出现 else ,全部展开成 else if 方便理解;
  3. 注意搜索区间和 while 的终止条件;
  4. 上、下界的更新方式与搜索区间存在联系;
  5. 查找重复元素的左/右边界的时候,当nums[mid] == target 时不要立即返回,而要收紧右/左侧边界以确定左/右边界。
posted on 2019-10-12 16:15  cv_gordon  阅读(167)  评论(0编辑  收藏  举报