当前位置: 首页 > news >正文

python-leetcode 62.搜索插入位置

题目:

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


方法一:二分查找

假设题意是在排序数组中寻找是否存在一个目标值,则可以利用二分法在Ologn的时间内找到是否存在目标值,但这题还有个额外条件,即如果不存在数组中的时候需要返回按顺序插入的位置。需要对二分法做些修改

考虑这个插入的位置pos,它成立的条件为:

nums[pos-1]<target<=nums[pos]

其中nums代表排序数组,由于如果存在这个目标值,返回的索引也是pos,即可以将两个条件合并后并得出最后的目标:在一个有序数组中找到第一个大于等于target的下标

问题转化到这个,直接套用二分法即可,即不断用二分法逼近查找第一个大于等于target的下标,ans初始设置为数组长度可以省略边界条件的判断,因为存在一种情况是target大于数组中的所有数,此时需要插入到数组长度的位置。

class Solution(object):
    def searchInsert(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: int
        """
        left=0  #指向数组的起始位置(索引0)
        right=len(nums)-1  #指向数组的末尾位置(最后一个元素的索引)
        while left<=right:  #左指针不大于右指针。这保证了搜索区间始终有效
            middle=(left+right)//2 #计算中间位置的索引
            if nums[middle]<target: #如果中间元素小于目标值,说明目标值应该在右半部分
                left=middle+1 #将左指针移动到中间位置右侧
            elif nums[middle]>target: #如果中间元素大于目标值,说明目标值应该在左半部分
                right=middle-1  #将右指针移动到中间位置左侧
            else:
                return middle
        return right+1  #循环结束还没找到目标值,right+1就是它应该插入的位置1

时间复杂度:O(logn)其中n为数组的长度

空间复杂度:O(1)

源自力扣官方题解

相关文章:

  • 阻止上传可执行程序
  • 实现Excel导入和导出
  • 服务器自动备份到本地,服务器自动备份到本地的方法有哪些?
  • [250401] OpenAI 向免费用户开放 GPT-4o 图像生成功能 | Neovim 0.11 新特性解读
  • MySQL和Oracle批量插入SQL差异详解
  • 青少年编程与数学 02-014 高中数学知识点 06课题、数学建模与探究活动
  • 第十一届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组
  • Java面试黄金宝典28
  • 单例模式(懒汉模式/饿汉模式)
  • 服务器数据恢复—误格式化NTFS文件系统分区别慌,NTFS数据复活秘籍
  • linux ubuntu下查询包是否包含某个工具
  • 移远通信推出超小Wi-Fi+BLE模组FGM842D系列,赋能智能家居与工业物联网高效互联
  • 【Easylive】MyBatis 批量插入或更新语句解析insertOrUpdateBatch
  • 12.小节
  • 关于React Redux
  • 【3. 软件工程】3.0 软件工程概述
  • Android View事件分发机制深度解析
  • QuecPython 的 VScode 环境搭建和使用教程
  • IS-IS认证
  • MySQL日志管理
  • 印度外交秘书:印巴军方将于12日再次对话
  • 乌外长:乌方准备无条件停火至少30天
  • 昆明一学校门外小吃摊占满人行道,城管:会在重点时段加强巡查处置
  • 19个剧团15台演出,上海民营院团尝试文旅融合新探索
  • 上市不足一年,吉利汽车拟私有化极氪并合并:整合资源,杜绝重复投入
  • 是谁提议特朗普向好莱坞征税?