数据结构和算法二(基础查找问题)

一、列表查找:


index(),是线性查找,因为二分查找需要进行排序

1、顺序查找

python 复制代码
def linear_search(data_set,value):
    for ind,val in enumerate(data_set):
        if val==value:
            return ind
    else:
        return

时间复杂度O(n),从头到尾循环一遍

2、二分查找



python 复制代码
def binary_search(data_set,value):
    left=0
    right=len(data_set)-1
    while left<right:
        mid=(left+right)//2
        if data_set[mid]==value:
            return mid
        elif data_set[mid]<value:
            left=mid+1
        else:
            right=mid-1
    return 0

时间复杂度O(logn)

原视频可参考:https://www.bilibili.com/video/BV1uA411N7c5?p=11\&spm_id_from=pageDriver\&vd_source=9baef983d7bc08245d4dee5c9e676ee9

相关推荐
xxwl5852 分钟前
工作室小测的部分记录
c++·学习·算法
智者知已应修善业6 分钟前
【51单片机串口通信甲机四个按键模拟四位二进制值发送乙机以十进制显示2位数码管】2024-6-14
c++·经验分享·笔记·算法·51单片机
KobeSacre6 分钟前
划分为k个相等的子集
算法·leetcode·深度优先
不会就选b8 分钟前
算法日常・每日刷题--<二分查找>2
算法
郝学胜_神的一滴13 分钟前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
数据结构·算法
asdzx6714 分钟前
Python 优雅解析 Excel:从原生行列到强类型对象的三层数据结构演进
数据结构·python·excel
coding者在努力15 分钟前
【无标题】
算法
兰令水18 分钟前
leecodecode【面试150】【2026.6.15打卡-java版本】
java·算法·面试
是苏浙22 分钟前
Java实现链表2
java·开发语言·数据结构
KobeSacre30 分钟前
ThreadLocal 源码
数据结构