[LeetCode] 33. Search in Rotated Sorted Array @ python

2024-04-14 02:38

本文主要是介绍[LeetCode] 33. Search in Rotated Sorted Array @ python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.题目:
有一个不含重复数字的升序数组,可能做了一些旋转操作,给定一个数查询是否存在这个数,若存在返回下标否则返回-1.时间复杂度为O(log n).
Example 1:

Input: nums = [4,5,6,7,0,1,2], target = 0
Output: 4

Example 2:

Input: nums = [4,5,6,7,0,1,2], target = 3
Output: -1

二.解题思路:
要求时间复杂度O(log n),提示我们使用二分搜索.这里要注意中间数字所在的区间是属于左边升序区间还是右边升序区间.代码如下:

class Solution(object):def search(self, nums, target):""":type nums: List[int]:type target: int:rtype: int"""#时间复杂度为O(log n),则考虑使用二分查找if not nums:return -1start = 0end = len(nums)-1while start <= end:mid = (start+end)/2if nums[mid] == target:return mid#当nums[mid]属于左边升序序列时if nums[mid] >= nums[start]:if target>=nums[start] and target<nums[mid]:end = mid -1else:start = mid +1#当nums[mid]属于右边升序序列时elif nums[mid] <= nums[end]:if target<=nums[end] and target>nums[mid]:start = mid +1else:end = mid -1return -1

如果这个数字可以包含重复数字,也就是leetcode上第81题,是上题的升级版.我们可以将其简化为上一题的版本,具体操作就是判断首尾两个元素是否相等,若不相等则将左指针一直往右移动.代码如下:

class Solution(object):def search(self, nums, target):""":type nums: List[int]:type target: int:rtype: bool"""N = len(nums)l, r = 0, N - 1while l <= r:while l < r and nums[l] == nums[r]:l += 1mid = l + (r - l) / 2if nums[mid] == target:return Trueif nums[mid] >= nums[l]:if nums[l] <= target < nums[mid]:r = mid - 1else:l = mid + 1elif nums[mid] <= nums[r]:if nums[mid] < target <= nums[r]:l = mid + 1else:r = mid - 1return False

这篇关于[LeetCode] 33. Search in Rotated Sorted Array @ python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/901874

相关文章

Python多进程、多线程、协程典型示例解析(最新推荐)

《Python多进程、多线程、协程典型示例解析(最新推荐)》:本文主要介绍Python多进程、多线程、协程典型示例解析(最新推荐),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 目录一、multiprocessing(多进程)1. 模块简介2. 案例详解:并行计算平方和3. 实现逻

Python对PDF书签进行添加,修改提取和删除操作

《Python对PDF书签进行添加,修改提取和删除操作》PDF书签是PDF文件中的导航工具,通常包含一个标题和一个跳转位置,本教程将详细介绍如何使用Python对PDF文件中的书签进行操作... 目录简介使用工具python 向 PDF 添加书签添加书签添加嵌套书签Python 修改 PDF 书签Pytho

利用Python实现可回滚方案的示例代码

《利用Python实现可回滚方案的示例代码》很多项目翻车不是因为不会做,而是走错了方向却没法回头,技术选型失败的风险我们都清楚,但真正能提前规划“回滚方案”的人不多,本文从实际项目出发,教你如何用Py... 目录描述题解答案(核心思路)题解代码分析第一步:抽象缓存接口第二步:实现两个版本第三步:根据 Fea

Python中CSV文件处理全攻略

《Python中CSV文件处理全攻略》在数据处理和存储领域,CSV格式凭借其简单高效的特性,成为了电子表格和数据库中常用的文件格式,Python的csv模块为操作CSV文件提供了强大的支持,本文将深入... 目录一、CSV 格式简介二、csv模块核心内容(一)模块函数(二)模块类(三)模块常量(四)模块异常

Python报错ModuleNotFoundError的10种解决方案

《Python报错ModuleNotFoundError的10种解决方案》在Python开发中,ModuleNotFoundError是最常见的运行时错误之一,通常由模块路径配置错误、依赖缺失或命名冲... 目录一、常见错误场景与原因分析二、10种解决方案与代码示例1. 检查并安装缺失模块2. 动态添加模块

python利用backoff实现异常自动重试详解

《python利用backoff实现异常自动重试详解》backoff是一个用于实现重试机制的Python库,通过指数退避或其他策略自动重试失败的操作,下面小编就来和大家详细讲讲如何利用backoff实... 目录1. backoff 库简介2. on_exception 装饰器的原理2.1 核心逻辑2.2

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法