【二分算法】

适用范围

有序的数据结构

选定区间

① [left, right]左闭右闭

right = numsize - 1
这种情况下,left = right是有意义的,故while(left <= right)

当nums[mid] > target时,right = mid - 1
当nums[mid] < target时,left = mid + 1

因为确定nums[mid]不是tartget

② [left, right)左闭右开

right = numsize
这种情况下,left = right没有意义,故while(left < right)
当nums[mid] > target时,right = mid
当nums[mid] < target时,left = mid + 1 注意此处还是mid+1,因为左边还是闭
因为是在左闭右开的区间中找,如果right = mid - 1,那就相当于把num[mid - 1]去掉了

最后附上C语言代码

// 左闭右闭
int search(int* nums, int numsSize, int target) {
   
    int left = 0;
    int right = numsSize - 1; // 此处为数组最大值的下标
    int mid = 0;

    while (left <= right)
    {
   
        mid = left + (right - left) / 2;
        if (nums[mid] == target)
            return mid;
        else if (nums[mid] > target)
            right = mid - 1;
        else if (nums[mid] < target)
            left = mid + 1;
    }
    return -1;
}
//左闭右开
int search(int* nums, int numsSize, int target) {
   
    int left = 0;
    int right = numsSize; // 此处为数组大小
    int mid = 0;

    while (left < right)
    {
   
        mid = left + (right - left) / 2;
        if (nums[mid] == target)
            return mid;
        else if (nums[mid] > target)
            right = mid;
        else if (nums[mid] < target)
            left = mid + 1; // 因为是左闭,还是mid + 1
    }
    return -1;
}

相关推荐

  1. 二分算法

    2023-12-16 02:18:02       39 阅读
  2. 二分算法

    2023-12-16 02:18:02       43 阅读
  3. 算法笔记—二分搜索

    2023-12-16 02:18:02       37 阅读
  4. 二分算法01

    2023-12-16 02:18:02       33 阅读
  5. 二分查找算法

    2023-12-16 02:18:02       28 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-16 02:18:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-16 02:18:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-16 02:18:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-16 02:18:02       20 阅读

热门阅读

  1. MapReduce\Shuffle

    2023-12-16 02:18:02       32 阅读
  2. 金融密钥管理方案:DUKPT

    2023-12-16 02:18:02       35 阅读
  3. PHP多维数组数据存储和读取

    2023-12-16 02:18:02       36 阅读
  4. 代码求解方程

    2023-12-16 02:18:02       43 阅读
  5. Makefile基本指令

    2023-12-16 02:18:02       38 阅读
  6. swift 多线程锁(一) NSLock

    2023-12-16 02:18:02       35 阅读
  7. MapReduce模拟统计每日车流量-解决方案

    2023-12-16 02:18:02       37 阅读
  8. Go 好用的Api

    2023-12-16 02:18:02       38 阅读
  9. Linux信号

    2023-12-16 02:18:02       40 阅读