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,不能把这个点包含进去。

目录
相关文章
|
1月前
【LeetCode 01】二分查找总结
【LeetCode 01】二分查找总结
13 0
|
3月前
|
Python
【Leetcode刷题Python】704. 二分查找
解决LeetCode "二分查找" 问题的Python实现代码。
18 0
|
3月前
|
算法 索引 Python
【Leetcode刷题Python】34. 在排序数组中查找元素的第一个和最后一个位置(二分查找)
解决LeetCode "在排序数组中查找元素的第一个和最后一个位置" 问题的方法。第一种方法是使用两次二分查找,首先找到目标值的最左边界,然后找到最右边界。第二种方法是利用Python的list.index()方法,先正序找到起始位置,再逆序找到结束位置,并给出了两种方法的Python实现代码。
60 0
|
5月前
力扣-2029-石子游戏-‘屎山’代码
力扣-2029-石子游戏-‘屎山’代码
40 3
|
5月前
|
索引
【LeetCode刷题】二分查找:山脉数组的峰顶索引、寻找峰值
【LeetCode刷题】二分查找:山脉数组的峰顶索引、寻找峰值
|
5月前
【LeetCode刷题】专题三:二分查找模板
【LeetCode刷题】专题三:二分查找模板
【LeetCode刷题】专题三:二分查找模板
|
5月前
|
算法 数据可视化 数据挖掘
深入解析力扣162题:寻找峰值(线性扫描与二分查找详解)
深入解析力扣162题:寻找峰值(线性扫描与二分查找详解)
|
6月前
|
算法 索引
【数据结构与算法 | 基础篇】力扣704/35/34:二分查找
【数据结构与算法 | 基础篇】力扣704/35/34:二分查找
|
5月前
【LeetCode刷题】二分查找:寻找旋转排序数组中的最小值、点名
【LeetCode刷题】二分查找:寻找旋转排序数组中的最小值、点名
|
5月前
|
算法
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值