Python算法题集_在排序数组中查找元素的第一个和最后一个位置

Python算法题集_在排序数组中查找元素的第一个和最后一个位置

  • 题34:在排序数组中查找元素的第一个和最后一个位置
  • 1. 示例说明
  • 2. 题目解析
    • - 题意分解
    • - 优化思路
    • - 测量工具
  • 3. 代码展开
    • 1) 标准求解【二分法+两次左边界】
    • 2) 改进版一【二分法+左右边界】
    • 3) 改进版二【第三方模块】
  • 4. 最优算法
  • 5. 相关资源

本文为Python算法题集之一的代码示例

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

1. 示例说明

  • 给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。

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

    你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。

    示例 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]
    

    提示:

    • 0 <= nums.length <= 105
    • -109 <= nums[i] <= 109
    • nums 是一个非递减数组
    • -109 <= target <= 109

2. 题目解析

- 题意分解

  1. 本题是在已排序列表中查找目标数值的左边界和右边界
  2. 最快方式就是二分法

- 优化思路

  1. 通常优化:减少循环层次

  2. 通常优化:增加分支,减少计算集

  3. 通常优化:采用内置算法来提升计算速度

  4. 分析题目特点,分析最优解

    1. 可以通过查找左边界的方式执行,查找目标的左边界+查找目标+1的左边界

    2. 可以通过查找左边界、右边界的方式执行

    3. 可以考虑使用排序列表操作模块bisect

- 测量工具

  • 本地化测试说明:LeetCode网站测试运行时数据波动很大【可把页面视为功能测试】,因此需要本地化测试解决数据波动问题
  • CheckFuncPerf(本地化函数用时和内存占用测试模块)已上传到CSDN,地址:Python算法题集_检测函数用时和内存占用的模块
  • 本题本地化超时测试用例自己生成,详见章节【最优算法】,代码文件包含在【相关资源】中

3. 代码展开

1) 标准求解【二分法+两次左边界】

二分法查询目标值左边界和目标+1左边界

页面功能测试,性能一般,超过78%在这里插入图片描述

import CheckFuncPerf as cfpclass Solution:def searchRange_base(self, nums, target):def searchbig(target: int) -> int:ileft, iright = 0, len(nums)while ileft < iright:imid = ileft + ((iright - ileft) >> 1)if nums[imid] > target:iright = imidelse:ileft = imid + 1return irightistart = searchbig(target - 1)if istart == len(nums) or nums[istart] != target:return [-1, -1]iend = searchbig(target)return [istart, iend - 1]aSolution = Solution()
result = cfp.getTimeMemoryStr(aSolution.searchRange_base, nums, itarget)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 运行结果
函数 searchRange_base 的运行时间为 0.00 ms;内存使用量为 4.00 KB 执行结果 = [33333333, 33333334]

2) 改进版一【二分法+左右边界】

二分法查询目标值左边界和右边界

页面功能测试,马马虎虎,超过56%在这里插入图片描述

import CheckFuncPerf as cfpclass Solution:def searchRange_ext1(self, nums, target):result = [-1, -1]def searchbymode(ileft, iright, modeflag):while ileft <= iright:imid = (ileft + iright) // 2if nums[imid] == target:if modeflag:result[0] = imidiright = imid - 1else:result[1] = imidileft = imid + 1elif nums[imid] > target:iright = imid - 1else:ileft = imid + 1searchbymode(0, len(nums) - 1, True)searchbymode(0, len(nums) - 1, False)return resultaSolution = Solution()
result = cfp.getTimeMemoryStr(aSolution.searchRange_ext1, nums, itarget)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 运行结果
函数 searchRange_ext1 的运行时间为 0.00 ms;内存使用量为 4.00 KB 执行结果 = [33333333, 33333334]

3) 改进版二【第三方模块】

使用排序列表操作模块bisect来查找左右边界

页面功能测试,马马虎虎,超过42%在这里插入图片描述

import CheckFuncPerf as cfpclass Solution:def searchRange_ext2(self, nums, target):from bisect import bisect_left, bisect_rightileft = bisect_left(nums, target)if ileft >= len(nums):return [-1, -1]if nums[ileft] != target:return [-1, -1]if ileft == len(nums)-1:return [ileft, ileft]if nums[ileft+1] != target:return [ileft, ileft]iright = bisect_right(nums[ileft+1:], target)return [ileft, ileft+iright]aSolution = Solution()
result = cfp.getTimeMemoryStr(aSolution.searchRange_ext2, nums, itarget)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 运行结果
函数 searchRange_ext2 的运行时间为 680.67 ms;内存使用量为 4.00 KB 执行结果 = [33333333, 33333334]

4. 最优算法

根据本地日志分析,最优算法为第1种方式【二分法+两次左边界】、第2种方式【二分法+左右边界】并列

本题测试数据,似乎能推出以下结论:

  1. 二分法查询性能非常夸张,简直是瞬间定位【1亿的数组,1毫秒定位】
  2. 第三方模块的算法估计是进行了切片操作
import random
ilen, istart = 100000000, 0
nums = [0 for x in range(ilen)]
for iIdx in range(ilen):istart += random.randint(0, 3)nums[iIdx] = istart
itarget = nums[ilen // 3]
aSolution = Solution()
result = cfp.getTimeMemoryStr(aSolution.searchRange_base, nums, itarget)
print(result['msg'], '执行结果 = {}'.format(result['result']))
result = cfp.getTimeMemoryStr(aSolution.searchRange_ext1, nums, itarget)
print(result['msg'], '执行结果 = {}'.format(result['result']))
result = cfp.getTimeMemoryStr(aSolution.searchRange_ext2, nums, itarget)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 算法本地速度实测比较
函数 searchRange_base 的运行时间为 0.00 ms;内存使用量为 4.00 KB 执行结果 = [33333333, 33333334]
函数 searchRange_ext1 的运行时间为 0.00 ms;内存使用量为 4.00 KB 执行结果 = [33333333, 33333334]
函数 searchRange_ext2 的运行时间为 680.67 ms;内存使用量为 4.00 KB 执行结果 = [33333333, 33333334]

5. 相关资源

本文代码已上传到CSDN,地址:Python算法题源代码_LeetCode(力扣)_在排序数组中查找元素的第一个和最后一个位置

一日练,一日功,一日不练十日空

may the odds be ever in your favor ~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/733095.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于YOLOv8深度学习的葡萄病害智能诊断与防治系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

寻找完全平方数——浮点数陷阱

【题目描述】 输出所有形如aabb的4位完全平方数&#xff08;即前两位数字相等&#xff0c;后两位数字也相等&#xff09;。 【解析】 一、问题分析 从问题出发&#xff0c;题目要求输出的是满足一定条件的数。数在计算机中是要占存储空间的&#xff0c;要在计算机中表示一个…

L1-035 情人节

以上是朋友圈中一奇葩贴&#xff1a;“2月14情人节了&#xff0c;我决定造福大家。第2个赞和第14个赞的&#xff0c;我介绍你俩认识…………咱三吃饭…你俩请…”。现给出此贴下点赞的朋友名单&#xff0c;请你找出那两位要请客的倒霉蛋。 输入格式&#xff1a; 输入按照点赞…

C语言字符串型常量

在C语言中&#xff0c;字符串型常量是由一系列字符组成的常量。字符串常量在C中以双引号&#xff08;"&#xff09;括起来&#xff0c;例如&#xff1a;“Hello, World!”。字符串常量在C中是不可变的&#xff0c;也就是说&#xff0c;一旦定义&#xff0c;就不能修改其内…

Web自动化测试流程:从入门到精通,帮你成为测试专家

摘要&#xff1a; Web应用程序在今天的软件开发中占据着越来越重要的地位。保证Web应用程序的质量和稳定性是非常必要的&#xff0c;而自动化测试是一种有效的方法。本文将介绍Web自动化测试流程&#xff0c;并提供代码示例。 步骤一&#xff1a;选取测试工具 选择适合自己团…

探讨代理IP在大数据收集、网络营销中的战略角色

代理IP在大数据收集和网络营销中扮演着至关重要的战略角色&#xff0c;其主要体现在以下几个方面&#xff1a; 1. 避免IP限制与反爬机制&#xff1a; - 在大数据收集过程中&#xff0c;尤其是网络爬虫抓取数据时&#xff0c;目标网站通常会设置访问频率限制或IP封锁策略以防止恶…

Linux作业调度和服务管理

目录 作业调度 调整进程的优先级 服务管理 systemd管理服务操作 systemd管理target&#xff08;一点点&#xff09; 作业调度的本质仍然是进程&#xff0c;之所以叫做作业调度&#xff0c;作业是以shell为单位的&#xff0c;一个shell建立的作业&#xff0c;不会被另外一个…

12 数据库安全和管理

文章目录 数据库安全和管理表的复制数据库备份MySQL远程连接添加用户和授权 数据库安全和管理 表的复制 表能根据实际需求复制数据复制表时不会把KEY属性复制过来 语法 create table 表名 select 查询命令;create table student select name,age,score from class where sc…

像SpringBoot一样使用Flask - 5.统一处理(日志、异常、响应报文)

接上文《像SpringBoot一样使用Flask - 4.拦截器》&#xff0c;通过拦截器处理一些日志&#xff0c;异常、还有统一的响应报文。 统一的目的就是为了让前后端调用请求不会因为各自习惯而随意编写&#xff0c;增加技术人员快速上手及代码的可阅读性。 一、定义一个返回类。是不是…

ZigBee技术与实践教程(持续更新笔记)

1.安全性 802.15.4 在数据传输过程中提供了三级安全性。 &#xff08;1&#xff09;第一级实际是无安全性方式&#xff0c;对于某种应用&#xff0c;如果安全性并不重要或者上一层已经提供了安全性保护&#xff0c;器件就可以采用这种方式来转移数据。 &#xff08;2&#x…

(已解决)报错:Could not load the Qt platform plugin “xcb“

完整报错信息 QObject::moveToThread: Current thread (0x6a879f0) is not the object’s thread (0x61bb590). Cannot move to target thread (0x6a879f0)qt.qpa.plugin: Could not load the Qt platform plugin “xcb” in “” even though it was found. This application…

深入了解 Python 的 compile() 函数

在 Python 中&#xff0c;compile() 是一个内置函数&#xff0c;用于将字符串形式的 Python 代码编译为可执行的代码对象&#xff0c;或者将 AST&#xff08;抽象语法树&#xff09;对象编译为代码对象。本文将深入探讨 compile() 函数的用法、参数和返回值&#xff0c;以及其在…

【Java】使用`LinkedList`类来实现一个队列,并通过继承`AbstractQueue`或者实现`Queue`接口来实现自定义队列

使用LinkedList类来实现一个队列&#xff0c;并通过继承AbstractQueue或者实现Queue接口来实现自定义队列。 以下是一个简单的示例&#xff0c;其中队列的大小与另一个List的容量保持一致&#xff1a; import java.util.LinkedList; import java.util.List; import java.util…

网络安全运营的工作内容(附资料下载)

【推荐】最新网络安全运营方案和实践合集&#xff08;共80多份&#xff09;.zip 网络安全运营的工作内容是一个多层次、多维度的体系&#xff0c;涵盖了多个关键领域以确保网络环境的稳定和安全。以下是一些主要的工作内容&#xff1a; 安全策略制定与实施&#xff1a; 制定网…

【前端Vue】Vue从0基础到大神完整教程第1篇:vue基本概念,vue-cli的使用【附代码文档】

Vue从0基础到大神学习完整教程完整教程&#xff08;附代码资料&#xff09;主要内容讲述&#xff1a;vue基本概念&#xff0c;vue-cli的使用&#xff0c;vue的插值表达式&#xff0c;{{ gaga }}&#xff0c;{{ if (obj.age > 18 ) { } }}&#xff0c;vue指令&#xff0c;综合…

20行代码搞定PDF表格转为Excel表

1.环境准备 安装好python并且配置好环境安装pdfplumber、xlwt库使用Vscode或者PyCharm等编辑器 在pycharm中如果报红&#xff0c;可以鼠标点击报红的库&#xff0c;altenter进行安装 2.代码部分 import pdfplumber import xlwt # 读取源pdf文件 pdf pdfplumber.open("…

2024-2030年再生混凝土市场供给规模及投资策略战略规划报告

2024-2030年再生混凝土市场供给规模及投资策略战略规划报告 《报告编号》: BG475174 《出版时间》: 2024年3月 《出版机构》: 中智正业研究院 《交付方式》: EMIL电子版或特快专递 《报告价格》:【纸质版】: 6500元 【电子版】: 6800元 【纸质电子】: 7000元 《 免费售后 服务…

图像处理ASIC设计方法 笔记8 卷积计算芯片的结构

(一) P81 卷积芯片内部模板框图 该设计有两个数据通路:图像数据和模板数据。 图像数据是经过帧控制、实时图SPRAM(写控制、 SPRAM读控制、数据读控制)、计算单元; 模板数据是经过模板SPRAM、计算单元。 4.5.4运算单元像素寄存器控制 存储SPRAM写入的64bit数据,输出为…

Unity2023.1.19_DOTS_JobSystem

Unity2023.1.19_DOTS_JobSystem 上篇我们知道了DOTS是包含Entity Component System&#xff0c;Job System&#xff0c;Burst compiler三者的。接下来看下JobSystem的工作原理和具体实现。 简介&#xff1a; 官方介绍说&#xff1a;JobSystem允许您编写简单而安全的多线程代…

C++篇 语 句

到目前为止&#xff0c;我们只见过两种语句&#xff1a; return 语句和表达式语句。根据语句对执行顺 序的影响&#xff0c;C 语言其余语句大多属于以下 3 大类。 选择语句&#xff1a; if 语句和 switch 语句。循环语句&#xff1a; while 语句&#xff0c; do...while 语句和…