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)

结果



小结

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

相关推荐
铸人4 分钟前
再论自然数全加和 - 欧拉伽马常数
数学·算法·数论·复数
m0_5312371726 分钟前
C语言-变量,枚举常量,字符串,打印类型,转义字符
c语言·数据结构·算法
张3蜂27 分钟前
Python venv 详解:为什么要用、怎么用、怎么用好
开发语言·python
zyeyeye31 分钟前
自定义类型:结构体
c语言·开发语言·数据结构·c++·算法
老赵全栈实战35 分钟前
《从零搭建RAG系统第3天:文档加载+文本向量化+向量存入Milvus》
python
火龙果研究院39 分钟前
在CentOS上安装Python 3.13需要从源码编译
开发语言·python·centos
俩娃妈教编程1 小时前
2023 年 03 月 二级真题(1)--画三角形
c++·算法·双层循环
龙山云仓1 小时前
No156:AI中国故事-对话司马迁——史家绝唱与AI记忆:时间叙事与因果之链
大数据·开发语言·人工智能·python·机器学习
niuniudengdeng1 小时前
一种基于高维物理张量与XRF实景复刻的一步闭式解工业级3D打印品生成模型
人工智能·python·数学·算法·3d
哈库纳玛塔塔1 小时前
公元前日期处理的两种方案
数据库·算法·mybatis