查找——顺序查找和二分查找

列表查找

输入:列表、待查找的元素
输出:元素下标(未找到元素时返回:None或者-1)

  • 内置查找函数 list.index()

顺序查找

从列表的第一个元素开始,顺序进行搜索,直到找到元素或搜索到列表最后一个为止

def linear_search(li,val):
	for ind,v in rnumberate(li):
		if v=val:
			return ind
	else:
		return None

时间复杂度 O ( n ) O(n) O(n)

二分查找

顺序排列的列表中直接查看中间数大小与所需数据进行比较

def binary_search(lst, val):  # lst为从小到大排序  
	left = 0  
	right = len(lst)  
	while left <= right:      # 候选区域有值  
		mid = (left+right)//2  
		if lst[mid] == val:  
			return mid  
        elif lst[mid] < val:  # 待查找值在mid右侧  
			left = mid + 1  
		elif lst[mid] > val:  # 待查找值在mid左侧  
			right = mid - 1 
	else:  
        return None

时间复杂度 O ( log ⁡ n ) O(\log n) O(logn)
but 无序的列表不适合用二分查找,因为排序的时间复杂度在 O ( n 2 ) O(n^{2}) O(n2) O ( n ) O(n) O(n) 之间

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值