leetcode代码记录(二分查找

简介: leetcode代码记录(二分查找

1. 题目:

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。


示例 1:

输入: nums = [-1,0,3,5,9,12], target = 9

输出: 4

解释: 9 出现在 nums 中并且下标为 4

示例 2:

输入: nums = [-1,0,3,5,9,12], target = 2

输出: -1

解释: 2 不存在 nums 中因此返回 -1

2. 我的代码:

左闭右闭法

class Solution:
    def search(self, nums: List[int], target: int) -> int:
        left_i = 0
        right_i = len(nums) - 1

        while left_i <= right_i:
            middle_i = (left_i + right_i) // 2
            if nums[middle_i] > target:
                right_i = middle_i - 1
            elif nums[middle_i] < target:
                left_i = middle_i + 1
            else:
                return middle_i
        
        return -1

左闭右开法:

class Solution:
    def search(self, nums: List[int], target: int) -> int:
        left_i = 0
        right_i = len(nums)

        while left_i < right_i:
            middle_i = (left_i + right_i) // 2
            if nums[middle_i] > target:
                right_i = middle_i
            elif nums[middle_i] < target:
                left_i = middle_i + 1
            else:
                return middle_i
        
        return -1

二分法还是比较好理解的,就相当于左右指针,并且用中间值去检查是否符合目标值。如果大于目标值,则说明右指针可以向左边靠拢;如果小于目标值,则说明左指针可以向右边靠拢。

对于左闭右闭法,即[left_i, right_i],while里放的应当是left_i <= right_i,因为left_i == right_i时这个值也需要检查,也就是还剩下一个值需要检查。

对于左闭右开法,即[left_i, right_i),while里放的应当是left_i < right_i,因为left_i == right_i时这个值不需要检查,左闭右开时这个区间是空。还有一个细节就是,nums[middle_i] > target时right_i = middle_i而不是middle_i - 1,不能把这个点包含进去。

目录
相关文章
|
4天前
|
机器学习/深度学习
leetcode代码记录(旋转图像
leetcode代码记录(旋转图像
9 0
|
4天前
|
算法
leetcode代码记录(全排列 II
leetcode代码记录(全排列 II
13 4
|
4天前
|
算法
leetcode代码记录(全排列
leetcode代码记录(全排列
12 1
|
4天前
|
索引
leetcode代码记录(Z 字形变换
leetcode代码记录(Z 字形变换
11 1
|
4天前
leetcode代码记录(最长回文子串
leetcode代码记录(最长回文子串
9 2
|
4天前
leetcode代码记录(回文数
leetcode代码记录(回文数
12 1
|
4天前
|
算法
leetcode代码记录(寻找两个正序数组的中位数
leetcode代码记录(寻找两个正序数组的中位数
13 2
|
4天前
leetcode代码记录(两数之和
leetcode代码记录(两数之和
11 1
|
4天前
|
索引
leetcode代码记录(最长公共子序列
leetcode代码记录(最长公共子序列
7 0
|
4天前
|
索引
leetcode代码记录(最长重复子数组
leetcode代码记录(最长重复子数组
12 0