704. Binary Search

Given an array of integers nums which is sorted in ascending order, and an integer target, write a function to search target in nums. If target exists, then return its index. Otherwise, return -1.

You must write an algorithm with O(log n) runtime complexity.

Example 1:

复制代码
Input: nums = [-1,0,3,5,9,12], target = 9
Output: 4
Explanation: 9 exists in nums and its index is 4

Example 2:

复制代码
Input: nums = [-1,0,3,5,9,12], target = 2
Output: -1
Explanation: 2 does not exist in nums so return -1

Constraints:

  • 1 <= nums.length <= 104
  • -104 < nums[i], target < 104
  • All the integers in nums are unique.
  • nums is sorted in ascending order.

1.左闭右开写法:

注意事项:区间内定义是否合法,主要表现为以下三个地方:

(1)int right=nums.size();

因为右边的是开,所以right的值应该比最大的下标+1

(2)while(left<right)

当left=right的时候,区间是不合法的,所以left!=right

(3)if(nums[middle]>target){

right=middle;

}

在这里,right=middle, 因为右边的是开,right的值是取不到的,所以可以等于middle。

还有一点就是后面else if的判断句,left=middle+1,如果写成left=middle的话,会超出时间限制。

复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left=0;
        int right=nums.size();
        while(left<right){
            int middle=(left+right)/2;
            if(nums[middle]>target){
                right=middle;
            }
            else if(nums[middle]<target){
                left=middle+1;
            }
            else{
                return middle;
            }
        }
        return -1;
    }
};

2.左闭右闭写法:

注意事项:依旧是区间的合法性,具体体现为以下四点:

(1)int right=nums.size()-1;

因为右边的是闭,所以right的值应该=最大的下标

(2)while(left<=right)

当left=right的时候,区间是合法的,所以left可以=right,不要漏了这个条件

(3)if(nums[middle]>target){

right=middle-1;

}

在这里,right=middle-1, 因为右边的是闭,right的值是取得到的,在if条件判断中已经判断了middle下标的值>target,如果不是middle-1的话,在边界条件上就会出问题了,因为右边是闭。

(4)else if(nums[middle]<target){

left=middle+1;

}

left=middle+1,理由同(3)

复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left=0;
        int right=nums.size()-1;
        while(left<=right){
            int middle=(left+right)/2;
            if(nums[middle]>target){
                right=middle-1;
            }
            else if(nums[middle]<target){
                left=middle+1;
            }
            else{
                return middle;
            }
        }
        return -1;
    }
};

总之,两种写法都可以,最重要的是看区间的边界是否合法。

相关推荐
一个有毅力的吃货8 分钟前
这个SKILL打通了AI写公众号文章的最后一公里
css·算法
free-elcmacom13 分钟前
C++ 函数占位参数与重载详解:从基础到避坑
java·前端·算法
Frostnova丶16 分钟前
LeetCode 1415. 长度为 n 的开心字符串中字典序第 k 小的字符串
数据结构·算法·leetcode
美好的事情能不能发生在我身上16 分钟前
Leetcode热题100中的:技巧专题
算法·leetcode·职场和发展
荣光属于凯撒18 分钟前
P15755 [JAG 2025 Summer Camp #1] JAG Box
c++·算法·贪心算法
AI科技星32 分钟前
基于v≡c空间光速螺旋量子几何归一化统一场论第一性原理的时间势差本源理论
人工智能·线性代数·算法·机器学习·平面
X-⃢_⃢-X36 分钟前
二、索引的数据结构
数据结构·mysql
云泽80836 分钟前
蓝桥杯算法精讲:哈夫曼编码的贪心思想与落地实现
算法·职场和发展·蓝桥杯
x_xbx42 分钟前
LeetCode:53. 最大子数组和
算法·leetcode·职场和发展
菜菜小狗的学习笔记43 分钟前
剑指Offer算法题(一)数组与矩阵
线性代数·算法·矩阵