11-代码随想录34在排序数组中查找元素的第一个和最后一个位置

34. 在排序数组中查找元素的第一个和最后一个位置

给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。

如果数组中不存在目标值 target,返回 [-1, -1]。

进阶:你可以设计并实现时间复杂度为 O ( log ⁡ n ) O(\log n) O(logn) 的算法解决此问题吗?

示例 1:

输入:nums = [5,7,7,8,8,10], target = 8

输出:[3,4]

示例 2:

输入:nums = [5,7,7,8,8,10], target = 6

输出:[-1,-1]

示例 3:

输入:nums = [], target = 0

输出:[-1,-1]

二分法

python 复制代码
def findtarget(nums,target):
    left,right=0,len(nums)-1
    s=[]
    while left<=right:
        middle=(right-left)//2+left
        if nums[middle]<target:
            left=middle+1
        elif nums[middle]>target:
            right = middle - 1
        else:
            s.append(middle)
            if nums[middle-1]==target:
                s.append(middle-1)
            if nums[middle+1]==target:
                s.append(middle+1)
            break
    if s==[]:
        print("[-1,-1]")
    else:
        print(s)


if __name__=='__main__':
    nums=input("nums=").split()
    target=str(input("target="))
    if nums==[]:
        print("[-1,-1]")
    else:
        findtarget(nums, target)

结果



小结

二分法,找到目标之后,可以在原地左右遍历就行了,不用用二分法整个都去查找核对,那样就跟暴力没什么区别。

相关推荐
菜菜的顾清寒1 分钟前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论
名字不好奇3 分钟前
大模型的思考模式:它真的在“想“吗?
人工智能·算法
Run_Teenage12 分钟前
算法模板:输入输出,并查集
java·开发语言·算法
大数据魔法师12 分钟前
Streamlit(十一)- API 参考文档(四)- 图表元素
python·web
AllData公司负责人19 分钟前
亲测丝滑,体验跃迁|AllData通过集成开源项目Datart,让数据可视化一目了然
java·大数据·数据库·python·数据可视化·数据视图·datart
高一学习c++会秃头吗22 分钟前
操作系统内存块分配算法
算法
tang7778923 分钟前
2026代理IP选型逻辑与成本控制:动态IP VS 静态IP、住宅IP VS 运营商IP VS 数据中心IP的深入解析
爬虫·python·代理ip·住宅ip·住宅代理·运营商ip
洛水水23 分钟前
【力扣100题】57.合并区间
算法·leetcode
玉树临风ives24 分钟前
atcoder ABC 458 题解
数据结构·c++·算法
如竟没有火炬34 分钟前
有序矩阵中第K小的元素
数据结构·线性代数·算法·leetcode·矩阵·深度优先