python中的min和in用代码实现

简介: min在 Python 中 min 函数可以直接返回列表中的最小项。现在用代码演示一下,怎么用代码实现在列表中检索一个最小项。def fn(L): MinIndex = 0 CurrentInder = 1 while C...

min

在 Python 中 min 函数可以直接返回列表中的最小项。
现在用代码演示一下,怎么用代码实现在列表中检索一个最小项。

def fn(L):
    MinIndex = 0
    CurrentInder = 1
    while CurrentInder < len(L):
        if L[MinIndex] > L[CurrentInder]:
            MinIndex = CurrentInder
        CurrentInder += 1
    return L[MinIndex]

L = [21,45,2,3,5,2,57,6,4]

print(fn(L))

解释一下

先把列表的第一项,也就是索引为0的值置为最小项,然后跟第二项,也就是索引为1的值进行比较,设置while循环,退出条件是列表的每一项都比较完。这样遍历了整个列表,最小项的索引也就找到了。
那最大项的索引岂不是改个条件就获取了,没错。试一下吧。

in

在python 中 in 的运算符用于在列表中搜索一个特定的项,这个列表没有要求。那这个in方法用代码实现起来就比较简单了。


def fn(L,target):
    position = 0
    while position < len(L):
        if L[position] == target:
            return ('索引是:{},值是:{}'.format(position,L[position]))
        position +=1
    return -1


L = [21,45,1,3,5,2,57,6,4]

print(fn(L,4))

只要挨个比较目标值就完事了。假如目标值不在列表中返回 -1 好了

但要考虑一件事,顺序搜索列表的性能怎么样呢?

  • 在最好的情况下,目标值正好在列表的前面,算法只进行了一次迭代就找到了目标值,复杂度为O(1)。
  • 最坏的情况下,目标项在列表的最末尾或者不在列表里,我们要比较n次(假如列表长度为n),那么最坏情况下,顺序搜索的复杂度为O(n)。
  • 再来考虑一下平均情况下的算法复杂度。要确定平均情况下,把在每一个可能的位置找到目标项所需的迭代次数相加,总和除以n,这样一算,算法执行了(n+n-1+n-2+ ++1)/2 或者 (n+1)/ 2 次迭代。对于很大的n ,常数因子2的作用不大,因此,平均情况下的复杂度仍然为O(n).

得出结论,顺序搜索最好情况的性能很少见,而平均情况和最坏情况的性能则基本相同。
对于没有按照任何顺序排列的数据,顺序搜索是必要的,当列表有序的时候,可以使用二叉搜索,又称二分查找。

二分查找

假设列表中的项都是按照升序排列的,二分查找就是先找到中间一项跟目标项进行比较,如果相等就返回该项的位置,也就是索引。否则,如果目标项比列表中间项大,就在中间项以后的位置查找,如果目标项比列表中间项小,就在中间项以前的位置查找。

def fn(L,target):
    left = 0
    right = len(L) - 1

    while left <= right:
        mid = (left + right) // 2
        if target == L[mid]:
            return mid
        elif target > L[mid]:
            left = mid + 1
        else:
            right = mid - 1
    return -1


L = [1,2,3,4,5,6,7,8,9]

print(fn(L,9))

首先设置 while 循环的退出条件是:查找的目标项跟列表中的中间项相等。

为了实现这个退出条件,我们一分为二这个列表,看看目标项在列表前后的哪个部分,当第一遍循环之后我们缩小一半的查找区域,再次循环又缩小一半。直到匹配出目标项。

对于大小为 n 的列表,实际上执行了 n/2/2/2/2/ 的连续除法,直到结果为1,假设 k 是用 n 除以 2 的次数。要求解k,让 n/2^k=1 就行了,那么 n=2^k,k=㏒₂n ,因此二分查找的复杂度为 O(k=㏒₂n)。

结语

最近会放上一些算法的文章,来锻炼算法能力。毕竟最底层的东西才是最实用的。

目录
相关文章
|
1天前
|
数据处理 开发者 Python
Python中的列表推导式:一种优雅的代码简化技巧####
【10月更文挑战第15天】 本文将深入浅出地探讨Python中列表推导式的使用,这是一种强大且简洁的语法结构,用于从现有列表生成新列表。通过具体示例和对比传统循环方法,我们将揭示列表推导式如何提高代码的可读性和执行效率,同时保持语言的简洁性。无论你是Python初学者还是有经验的开发者,掌握这一技能都将使你的编程之旅更加顺畅。 ####
9 1
|
2天前
|
人工智能 IDE 测试技术
使用通义灵码提升Python开发效率:从熟悉代码到实现需求的全流程体验
作为一名Python开发者,我最近开始使用通义灵码作为开发辅助工具。它显著提高了我的工作效率,特别是在理解和修改复杂代码逻辑方面。通过AI编码助手,我能够在短时间内快速上手新项目,实现新需求,并进行代码优化,整体效率提升了60%以上。通义灵码不仅加快了代码生成速度,还增强了代码的健壮性和稳定性。
|
3天前
|
缓存 程序员 开发者
探索Python中的装饰器:一种优雅的代码增强技巧
【10月更文挑战第13天】 在本文中,我们将深入探讨Python中的装饰器,这是一种强大的工具,它允许程序员以简洁而高效的方式扩展或修改函数和类的行为。通过具体示例,我们将展示如何利用装饰器来优化代码结构,提高开发效率,并实现如日志记录、性能计时等常见功能。本文旨在为读者提供一个关于Python装饰器的全面理解,从而能够在他们的项目中灵活运用这一技术。
13 1
|
8天前
|
设计模式 开发者 Python
Python中的装饰器:简化代码与增强功能
【10月更文挑战第9天】在编程的世界里,效率和可读性是衡量代码质量的两大关键指标。Python语言以其简洁明了的语法赢得了无数开发者的青睐,而装饰器则是其独特魅力之一。本文将深入探讨装饰器的工作原理、使用方法以及如何通过自定义装饰器来提升代码的重用性和可维护性,让读者能够更加高效地编写出既优雅又功能强大的代码。
|
9天前
|
缓存 Python
探索Python中的装饰器:简化你的代码之道
【10月更文挑战第8天】在Python的世界里,装饰器就像是一把瑞士军刀,小巧却功能强大。它们能够优雅地修改函数的行为,让代码更加简洁而不失强大。本文将带你走进装饰器的奇妙世界,从基础概念到实战应用,一步步解锁装饰器的秘密,让你的Python代码更上一层楼。
|
8天前
|
设计模式 存储 缓存
Python中的装饰器:提高代码可读性和复用性
【10月更文挑战第9天】Python中的装饰器:提高代码可读性和复用性
12 1
|
8天前
|
IDE 网络安全 开发工具
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
本文介绍了如何在PyCharm专业版中连接远程服务器并配置远程Python环境解释器,以便在服务器上运行代码。
56 0
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
|
9天前
|
设计模式 测试技术 开发者
Python中的装饰器:提升代码复用与模块化的艺术
本文将带你领略Python装饰器的魔力,探索如何通过装饰器来增强函数功能而不修改其代码。我们将从装饰器的基础概念出发,逐步深入到如何在实际项目中应用装饰器,以及如何编写自定义装饰器。文章最后,我们将通过一个实例,展示装饰器在日志记录和性能测试中的应用,让你的代码更加模块化和可重用。
|
9天前
|
Python
Python实用记录(十一):出现科学计数法如何在代码中恢复
本文介绍了如何在Python中处理科学计数法,包括如何将科学计数法转换为普通数字,以及如何设置NumPy的print选项来避免科学计数法的显示。
31 1
|
10天前
|
开发者 Python
探索Python中的列表推导式:简化代码的利器
在Python编程中,列表推导式是一种简洁而强大的工具,它允许开发者以一行代码实现复杂的列表操作。本文将深入探讨列表推导式的语法、优势以及实际应用,帮助读者更好地利用这一特性来优化代码。