Leetcode 35.搜索插入位置(Search Insert Position)

Leetcode 35.搜索插入位置

1 题目描述(Leetcode题目链接

  给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。你可以假设数组中无重复元素。

输入: [1,3,5,6], 5
输出: 2

输入: [1,3,5,6], 2
输出: 1

输入: [1,3,5,6], 7
输出: 4

输入: [1,3,5,6], 0
输出: 0

2 题解

  二分法查找正确位置,关键在于边界的处理,循环限制条件最好为 l e f t < r i g h t left<right left<right,这样会确保在退出循环的时候 l e f t = r i g h t left = right left=right,避免了要思考到底是返回哪个值。于此题,由于要插入正确位置,那么应该将数组的长度加一来看待,规定右边界的值为数组长度,左边界值为0,接下来要判断二分过程中 m i d mid mid与左右边界值的关系:如果 t a r g e t > n u m s [ m i d ] target>nums[mid] target>nums[mid]说明,目标位置一定在 m i d mid mid右侧,应该 l e f t = m i d + 1 left = mid + 1 left=mid+1,反之,如果 t a r g e t ≤ n u m s [ m i d ] target \le nums[mid] targetnums[mid],则目标位置可能在 m i d mid mid处,也可能在 m i d mid mid左侧,应该 r i g h t = m i d right = mid right=mid

class Solution:
    def searchInsert(self, nums: List[int], target: int) -> int:
        if not nums:
            return 0
        i, j = 0, len(nums)
        while i < j:
            mid = (i + j)//2
            if target > nums[mid]:
                i = mid + 1
            else:
                j = mid
        return i
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值