python 二分查找

1.二分查找首先被查找的序列是一个有序的。

2.明确序列的左右边界

3.找出序列中间的元素,判断如果是要查找的元素,返回元素

4.如果中间元素,大于或者小于查找的元素,那么改变左右边间,直到中间的数等于查找的元素。

python 复制代码
def Two_selecter(find_num,nums):
    #划定左右边界下标
    left,right = 0,len(nums)-1
    while left <= right:
        #计算出折半值的下标
        pivot = left + (right - left) // 2
        #如果相等,就找到了,返回值
        if nums[pivot] == find_num:
            return nums[pivot]
        #如果小于中间值,中间值的下标退一位,变成右边界
        if find_num < nums[pivot]:
            right = pivot - 1
        #如果中间值小于查找值,中间值+1,变成左边界
        else:
            left = pivot + 1
    return None

a = [1,2,3,4,5,6,7,8,9,10]
print(Two_selecter(2,a))
相关推荐
程序员敲代码吗5 分钟前
解析Kotlin中元组的多返回值实现
android·开发语言·kotlin
Java后端的Ai之路7 分钟前
【 Java】-网络协议核心知识问答(比较全)
java·开发语言·网络协议
小陈phd7 小时前
多模态大模型学习笔记(七)——多模态数据的表征与对齐
人工智能·算法·机器学习
雨泪丶7 小时前
代码随想录算法训练营-Day35
算法
pursuit_csdn8 小时前
LeetCode 1022. Sum of Root To Leaf Binary Numbers
算法·leetcode·深度优先
nimadan128 小时前
**AI漫剧软件2025推荐,解锁高性价比创意制作新体验**
人工智能·python
NAGNIP8 小时前
一文搞懂神经元模型是什么!
人工智能·算法
董董灿是个攻城狮9 小时前
AI 视觉连载6:传统 CV 之高斯滤波
算法
姜太公钓鲸23310 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript