美文网首页极客时间:数据结构与算法之美笔记
二分查找(下):二分查找的4个变形问题(3,4)

二分查找(下):二分查找的4个变形问题(3,4)

作者: 红酥手黄藤酒丶 | 来源:发表于2019-01-15 23:12 被阅读0次

二分查找(下):二分查找的4个变形问题(3,4)

  • 查找第一个 大于等于给定值 的元素
  • 查找最后一个 小于等于给定值 的元素

一、查找第一个 大于等于给定值 的元素

思路,取中间结点与给定值比较,若大于给定值,则要判断该值是否是第一个大于等于给定值的数据,所以要判断此时的中间结点下标是否是 0,若是则一定是第一个大于等于给定值的元素。若不是 0,则判断中间结点的前一个结点 mid - 1 是否小于给定值,若小于,则表示mid 一定是第一个大于等于给定值的数据。若都不满足则继续二分。

public int bsearch(int[] a, int n, int value) {
  int low = 0;
  int high = n - 1;
  while (low <= high) {
    int mid =  low + ((high - low) >> 1);
    if (a[mid] >= value) {
      if ((mid == 0) || (a[mid - 1] < value)) return mid;
      else high = mid - 1;
    } else {
      low = mid + 1;
    }
  }
  return -1;
}

二、查找最后一个小于等于给定值的元素

public int bsearch7(int[] a, int n, int value) {
  int low = 0;
  int high = n - 1;
  while (low <= high) {
    int mid =  low + ((high - low) >> 1);
    if (a[mid] > value) {
      high = mid - 1;
    } else {
      if ((mid == n - 1) || (a[mid + 1] > value)) return mid;
      else low = mid + 1;
    }
  }
  return -1;
}

思路与第一个问题一致。

解答开篇:如何快速定位出一个 IP 地址的归属地?

image

相关文章

  • 二分查找(下):二分查找的4个变形问题(3,4)

    二分查找(下):二分查找的4个变形问题(3,4) 查找第一个 大于等于给定值 的元素 查找最后一个 小于等于给定值...

  • 算法-查找-二分查找变形

    经典的二分查找很好理解,也很好实现,那一起来看下二分查找的变形问题。常见的二分查找变形问题有: 查找第一个等于待查...

  • 16-二分查找(下):如何快速定位IP对应的省份地址?

    上一节介绍了最简单的一种二分查找,接下来讲几种二分查找的变形问题。 有这样一个说法:“十个二分九个错”。二分查找虽...

  • SearchInRotatedAry

    其实这个问题,是基于二分查找(BinarySearch)来解决的。所以这里需要先理解一下二分查找。 1. 二分查找...

  • [老实李] 算法初探:二分查找法 Binary Search

    二分查找法主要用来解决查找的问题 1、二分查找法Binary Search (注)对于有序数列才能使用二分查找法。...

  • 数据结构和算法--二分查找

    二分查找 二分查找的思想 二分查找(Binary Search)算法,也叫折半查找算法。 二分查找针对的是一个有序...

  • python二分查找算法

    文章概述 二分查找法介绍 简单查找与二分查找对比 二分查找  二分查找算法主要思想:在有序列表中查找指定元素,先从...

  • 二分查找

    [TOC] 二分查找的基础模板 二分查找靠左的Index基础模板 二分查找靠右的Index基础模板 二分查找插入t...

  • 二分查找--变形问题

    1.查找第一个等于给定值的元素 2.查找最后一个等于给定值的元素 3.查找第一个大于等于给定值的元素 4.查找最后...

  • 二分查找

    什么是二分查找?二分查找,也叫折半查找(Binary Search),它是一种效率较高的查找方法。二分查找的条件:...

网友评论

    本文标题:二分查找(下):二分查找的4个变形问题(3,4)

    本文链接:https://www.haomeiwen.com/subject/gaoudqtx.html