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

一、列表查找:


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

相关推荐
ZPC82105 小时前
PPO训练小车
人工智能·算法·机器人
bksczm5 小时前
二分查找的细则(binary search)
算法
A923A5 小时前
【洛谷刷题 | 第三天】
算法·二分·洛谷·pair
abant25 小时前
leetcode912 排序算法总结
算法·leetcode·排序算法
@猿程序5 小时前
ShardingSphere自定义分片算法与Redis动态规则加载实战
网络·redis·算法
Share_Shun5 小时前
【定位引导】多点对位算法
算法
炽烈小老头5 小时前
【 每天学习一点算法 2026/03/18】全排列
学习·算法
Book思议-5 小时前
【数据结构实战】判断链表是否有环:快慢指针法(Floyd 判圈算法)
c语言·数据结构·算法·链表