Python 每日一练 二分查找 搜索旋转排序数组 详解

简介: Python 每日一练 二分查找 搜索旋转排序数组 详解

大一在读 大数据管理与应用专业 欢迎交流


备战蓝桥杯 倒计时71天


目前主要学习Python算法与数据结构 今日主题:二分查找


算法人算法魂 算法题让我们敢于挑战自己做意想不到的事情


如果还没接触过二分查找的可以看一下小郑上一篇博客保证入门简简单单(有模板)(属于优化版 适用很多场景 但今天这道题用起来就相形见绌了)


今天这个二分写法与上面的模板有所不同 是最基本的写法👇很简单对吧

#核心框架

while a<=b:
    mid=(a+b)//2
    if nums[mid]==target:
        return mid
    elif nums[mid]>target:
        b=mid-1
    else:
        a=mid+1

👇👇现在来让我们试试手


问题描述:

image.png


如果你觉得比较难?先看看这种方法


Python 自带函数解法:index函数用法传送门

Python List index()方法 | 菜鸟教程 (runoob.com)

https://www.runoob.com/python/att-list-index.html


class Solution:
    def search(self, nums: List[int], target: int) -> int:
        return nums.index(target) if target in nums else -1

image.png

二分查找法:


你肯定会说 ''这是无序的!!   二分查找只能用于有序数组 ''


对的 二分查找的确只能用于有序数组

但是审题后我们会发现:nums是由升序数组旋转得到(旋转规则根据题意可知)

先说结论 旋转后的数组 指针定在任意一个位置 那么两段序列中至少有一段是升序的

                                                   (我知道你有点不完全相信我!!)


但事实就是如此:

image.png


第一行是未旋转的升序序列 第二行是旋转后的


当指针指向中间 有两段升序序列


当指针指向右边(2)2到n-1是升序的 n到2不是升序的 因此有一段升序序列


当指针指向左边(n+1)n到n+1是升序的 n+1到n-1不是升序的 因此有一段升序序列


所以说明上面的结论是正确的 (或许你可能觉得我这样证明还不严谨)


那下面给出严格证明:假设数列元素>2个 (一个旋转了还是本身)


设k为分界点 下标0-k升序 下标k-len(nums)-1升序 对数列进行旋转


旋转后 指针指向k 旋转数列有两段升序序列 指向<k的位置 k左半边是有序


指向>k的位置 k右半边是有序   证明完毕


代码设计思路:拿到旋转后的数组  划分区域:有序的 无序的

对有序的二分查找 如果找到 大功告成

如果找不到 返回第一步 再次对第一轮的无序区域划分有序区域和无序区域

发现了吗?这其实就是一个递归的过程 因此我们设置两个指针l和r 用来递归每一次的无序区间 😀


class Solution:
    def search(self, nums: List[int], target: int) -> int:
        def Binary_search(l,r,target):
            if l==r and nums[l]!=target:return -1  
            mid=(l+r)//2#至少有一段是完全递增的
            if nums[mid]<nums[l]:#有序区间在右,对其对分查找
                a,b=mid,r
                while a<=b:
                    middle=(a+b)//2
                    if nums[middle]==target:
                        return middle
                    elif nums[middle]>target:
                        b=middle-1
                    else:
                        a=middle+1
                return Binary_search(l,mid-1,target)#如果右有序区间没找到 去找左无序区间
            else:#有序区间在左,对其对分查找
                a,b=l,mid
                while a<=b:
                    middle=(a+b)//2
                    if nums[middle]==target:
                        return middle
                    elif nums[middle]>target:
                        b=middle-1
                    else:
                        a=middle+1
                return Binary_search(mid+1,r,target)#如果左有序区间没找到 去找右无序区间
        return Binary_search(0,len(nums)-1,target)

image.png

好啦 今天的每日一练就到这里 祝大家新年快乐😀和小郑一起加油  


目录
相关文章
|
负载均衡 Linux 数据库
阿里云轻量应用服务器套餐收费标准参考(组合套餐、负载均衡套餐等)
阿里云轻量应用服务器有多种套餐,在购买轻量应用服务器、轻量应用负载均衡、轻量容器服务和轻量数据库服务时,我们可以根据业务需求选择合适的套餐。本文为大家介绍阿里云轻量应用服务器套餐和镜像最新价格表以及相关收费说明。
1034 0
阿里云轻量应用服务器套餐收费标准参考(组合套餐、负载均衡套餐等)
|
3月前
|
人工智能 前端开发 Docker
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
在 AI 智能体开发中,开发者常面临本地调试与云端部署的矛盾。本文介绍如何通过 Docker Compose 与 Docker Offload 解决这一难题,实现从本地快速迭代到云端高效扩容的全流程。内容涵盖多服务协同、容器化配置、GPU 支持及实战案例,助你构建高效、一致的 AI 智能体开发环境。
345 2
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
|
4月前
|
JSON 监控 数据可视化
揭秘淘宝 API,让天猫店铺流量来源一目了然
在竞争激烈的电商环境中,天猫商家最关心的问题之一是流量来源。本文介绍如何利用淘宝开放平台的API接口,帮助商家清晰掌握店铺流量渠道,包括直接访问、搜索、广告及社交媒体流量。通过API获取数据后,可进一步分析访问量、来源占比、跳出率等关键指标,优化营销策略,提升转化率。结合Python编程与图表工具,实现数据可视化分析,助力商家做出数据驱动决策,抢占市场先机。
472 0
|
9月前
|
Java Linux 定位技术
Minecraft配置文件参数说明(JAVA服务器篇)
Minecraft JAVA版服务器启动后会生成server.properties配置文件,位于minecraft_server/根目录下。该文件包含多项关键设置,如游戏模式(gamemode)、最大玩家数(max-players)、难度(difficulty)等。此文档详细说明了各配置项的功能与默认值,帮助用户高效管理服务器环境。
1979 60
|
安全 测试技术 数据安全/隐私保护
原生鸿蒙的竞争力到底如何?
长期以来,移动操作系统市场被IOS和安卓所垄断,一直都难以推出完整的自主系统,面临诸多挑战,如推广困难、应用适配难度大,以及技术底座缺乏自主性。但原生鸿蒙操作系统展示其在突破这些瓶颈方面的努力,基于安全牢固的“鸿蒙内核”,上层应用的开发与创新得以实现,不再被卡脖子,更不牵制于外界。本身该系统在OS内核、框架、数据库等方面进行全面自研,实现真正的自主可控。
430 2
|
存储 JSON 安全
Token验证技术文档
【7月更文挑战第6天】Token验证是现代Web应用中常见的安全措施,用于确保用户身份的合法性和请求的安全性。它基于令牌(Token)的概念,通过在客户端和服务端之间传递一个安全的、有时限的字符串来验证用户身份,替代传统的基于会话的认证机制。本文档旨在介绍一种基本的Token验证流程,并提供一个简单的代码示例,使用JSON Web Tokens (JWT) 实现这一过程。
1644 1
|
机器学习/深度学习 自然语言处理 PyTorch
PyTorch 中的动态图与静态图:理解它们的区别及其应用场景
【8月更文第29天】深度学习框架中的计算图是构建和训练神经网络的基础。PyTorch 支持两种类型的计算图:动态图和静态图。本文旨在阐述这两种计算图的区别、各自的优缺点以及它们在不同场景下的应用。
3326 0
|
监控 算法 自动驾驶
软件体系结构 - 调度算法(1) 最早截至时间优先
【4月更文挑战第19天】软件体系结构 - 调度算法(1) 最早截至时间优先
931 0
|
机器学习/深度学习 算法 API
量子计算编程语言:面向未来的开发工具
量子计算编程语言是面向未来的开发工具,基于量子力学原理,能够突破经典计算的瓶颈。本文介绍了量子计算编程语言的发展历程、主要特点、应用前景及学习方法,涵盖了QCL、Q#、Quipper等代表性语言,以及Qiskit、ProjectQ等主流工具,为开发者提供了全面的学习路径。
|
存储 关系型数据库 MySQL
智能调度、秒级弹性|一文带你探索Compaction Service的进化之路
ADB MySQL的Compaction Service功能通过将Compaction任务从存储节点解耦至独立的弹性资源池执行,解决了资源隔离性弱、并发度低等问题,实现了资源消耗降低50%,任务执行时间平均减少40%,并支持按量付费,提升了系统的稳定性和成本效益。