【Python】(十三)Python中的查找

Python中最简单的查找方法

in运算符是python中最简单的查找方法。

>>> 15 in [3,5,2,4,1]
False
>>> 3 in [3,5,2,4,1]
True

这种方法简单而且高效。但为了加深对查找算法的理解,我们还会尝试用python实现一些简单查找算法的逻辑。

顺序查找

顺序查找是一种非常简答的查找方式。从第一个项开始,逐一遍历整个列表,直到找到需要找的元素。当遍历完整个列表仍然没有找到时,则说明需要查找的元素并不在列表中。

# 顺序查找
# items_list为元素列表,item为需要查找的元素
# 查找到时返回True,没有找到时则返回False
def sequentialSearch(items_list, item):
    index = 0
    while index<len(items_list): #逐个遍历
        if item == items_list[index]: #找到元素,返回True
            return True
        index += 1
    return False #遍历结束依然没能找到,则返回False

def main():
    testlist = [1, 2, 32, 8, 17, 19, 42, 13, 0]
    print(sequentialSearch(testlist, 3))
    print('-----------------')
    print(sequentialSearch(testlist, 13))
    print('-----------------')
    print(sequentialSearch(testlist, 0))
    
if __name__ == "__main__":
    main()

运行结果为:

False
-----------------
True
-----------------
True

无序列表顺序查找的时间复杂度为O(n)。
当列表不包含所查元素时,有序列表可以比无序列表更早的停止遍历,但时间复杂度也依然是O(n)。

二分查找

二分查找是一种针对有序数列的查找方式。
二分查找从中间项开始,而不是按顺序查找列表。 如果该项是我们正在寻找的项,我们就完成了查找。 如果它不是,我们可以使用列表的有序性质来消除剩余项的一半。如果我们正在查找的项大于中间项,就可以消除中间项以及比中间项小的一半元素。如果该项在列表中,肯定在大的那半部分。
这里,我们暂时不考虑排序的问题,只实现二分查找本身:

# 二分查找
# items_list为升序排序后的元素列表,item为需要查找的元素
# 查找到时返回True,没有找到时则返回False
def binaryChop(items_list, item):
    leftpos = 0
    rightpos = len(items_list)-1
    while leftpos<=rightpos :
        midpos = (leftpos+rightpos)//2 #中点位置
        if items_list[midpos] == item: #找到元素
            return True
        elif items_list[midpos] < item: #元素可能在比中点更大的一侧
            leftpos = midpos+1
        else: #元素可能在比中点更小的一侧
            rightpos = midpos-1
    return False #没能找到,则返回False

def main():
    testlist = [0, 1, 2, 8, 13, 17, 19, 32, 42]
    print(binaryChop(testlist, 3))
    print('-----------------')
    print(binaryChop(testlist, 13))
    print('-----------------')
    print(binaryChop(testlist, 0))
    
if __name__ == "__main__":
    main()

运行结果如下:

False
-----------------
True
-----------------
True

我们也可以采用递归的写法来书写这段代码,让程序的逻辑更加清晰:

# 二分查找2
# items_list为升序排序后的元素列表,item为需要查找的元素
# 查找到时返回True,没有找到时则返回False
def binaryChop_2(items_list, item):
    if 0 == len(items_list): #待查列表已经为空
        return False
    midpos = (len(items_list)-1)//2 #中点
    if items_list[midpos] == item: #找到元素
        return True
    elif items_list[midpos] < item: #元素可能在比中点更大的一侧
        return binaryChop_2(items_list[midpos+1:], item)
    else: #元素可能在比中点更小的一侧
        return binaryChop_2(items_list[:midpos], item)

def main():
    testlist = [0, 1, 2, 8, 13, 17, 19, 32, 42]
    print(binaryChop_2(testlist, 3))
    print('-----------------')
    print(binaryChop_2(testlist, 13))
    print('-----------------')
    print(binaryChop_2(testlist, 0))
    
if __name__ == "__main__":
    main()

运行结果依然是:

False
-----------------
True
-----------------
True

二分查找的时间复杂度为O(logn)要低于顺序查找的时间复杂度。但考虑到二分查找需要进行排序,因而二分查找并不一定在任何场合都好于顺序查找。如果在小数据上进行单次查找,那么直接使用顺序查找是更为适合的。如果在大数据上需要进行多次频繁的查找,那么排序的时间成本就可以被分摊得很低,这种场景最适合使用二分查找。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • 第一章 绪论 什么是数据结构? 数据结构的定义:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 第二章...
    SeanCheney阅读 5,764评论 0 19
  • 一、相关定义 查找——查找就是根据给定的某个值,在查找表中确定一个其关键字等于给定值的数据元素(或记录)。所有这些...
    开心糖果的夏天阅读 1,123评论 0 8
  • 原文出处:http://www.cnblogs.com/maybe2030/p/4715035.html引文出处:...
    明教de教主阅读 9,167评论 0 7
  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,096评论 0 12
  • 空山新雨后,天气晚来秋。 明月松间照,清泉石上流。 竹喧归浣女,莲动下渔舟。 随意春芳歇,...
    冰心兰草阅读 543评论 0 0