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

一、列表查找:


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

相关推荐
m0_7066532313 分钟前
基于C++的爬虫框架
开发语言·c++·算法
diediedei21 分钟前
嵌入式数据库C++集成
开发语言·c++·算法
君义_noip22 分钟前
洛谷 P3388 【模板】割点(割顶)
c++·算法·图论·信息学奥赛·csp-s
xie0510_23 分钟前
string模拟实现
开发语言·c++·算法
xuedingbue40 分钟前
数据结构与顺序表:高效数据管理秘籍
数据结构·算法·链表
星火开发设计1 小时前
共用体 union:节省内存的特殊数据类型
java·开发语言·数据库·c++·算法·内存
求梦8201 小时前
【力扣hot100题】合并两个有序链表(22)
算法·leetcode·链表
dcmfxvr1 小时前
adwawd
算法
啊阿狸不会拉杆1 小时前
《数字信号处理 》第 7 章-无限长单位冲激响应 (IIR) 数字滤波器设计方法
数据结构·算法·信号处理·数字信号处理·dsp
IT_Octopus1 小时前
力扣热题100 20. 有效的括号
算法·leetcode