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)。

结语

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

python中in_python中的min和in用代码实现相关推荐

  1. 实际上,Python 3.3中新的“ yield from”语法的主要用途是什么?

    本文翻译自:In practice, what are the main uses for the new "yield from" syntax in Python 3.3? I ...

  2. python中可以用中文作为变量-在Python 3.x中可以使用中文作为变量名。

    [判断题]Python变量使用前必须先声明,并且一旦声明就不能再当前作用域内改变其类型. [填空题]Python内置函数__用来返回序列中的最大元素 [填空题]表达式 int(4**0.5) 的值为 ...

  3. Python 3.x中reduce()函数完整用法

    在Python 3.x中,reduce()不再是内置函数,而是移到了标准库functools中,需要先导入再使用,其官方解释如图所示: 从官方文档可知,该函数用法要点如下: 1)把一个双参数函数以累积 ...

  4. python利用表格中的某一个列_python取excel表格第一列数据?python操作excel,使用xlrd模块,获取某一列数据的语句为...

    用Python修改excel中一列数据 可以使用pandas库,先读取excel文件,然后使用pandas库来修改一列,然后写入文件即可. 怎样用python,读取excel中的一列数据 sheet. ...

  5. python 实现maltab中离散正弦变换dst及其反变换idst

    DFT.DCT.DST数学公式及原理部分可参考该博客. 笔者在将某matlab程序代码重新用python实现过程中,发现scipy.fft.dst的运行结果和matlab中的dst函数运行结果不一致( ...

  6. python中formatter的用法_Python pyplot.FuncFormatter方法代码示例

    本文整理汇总了Python中matplotlib.pyplot.FuncFormatter方法的典型用法代码示例.如果您正苦于以下问题:Python pyplot.FuncFormatter方法的具体 ...

  7. python统计列表中元素个数_python中计算一个列表中连续相同的元素个数方法

    python中计算一个列表中连续相同的元素个数方法 最简单的例子: a = [1,1,1,1,2,2,2,3,3,1,1,1,3] # 问:计算a中最多有几个连续的1 很明显,答案是4 如果用代码实现 ...

  8. python入门(中)

    python入门(中) 一.简介 二.列表 1.列表的定义 2.列表的创建 3.向列表中添加元素 4.删除列表中的元素 5.获取列表中的元素 6.列表的常用操作符 7.列表的其它方法 三.元组 1.创 ...

  9. 【附源码】用Python从文件中读取学生成绩,并计算最高分/最低分/平均分

    兄弟们, 今天咱们试试用Python从文件中读取学生成绩, 并计算最高分/最低分/平均分. 涉及知识点 文件读写 基础语法 字符串处理 循环遍历 代码展示 模块 import platform 定义获 ...

最新文章

  1. linux 找出谁杀了进程
  2. 使用Github+Hexo框架搭建部署自己的博客
  3. 计算机漫游用户的工作原理,深入理解计算机系统——计算机系统漫游
  4. 计算机网络面试题整理
  5. AdminLTE介绍
  6. 1211笔记关于//modal//更改窗口的根控制器//数据存取//Plist属性列表//-“沙盒机制”//plis属性列表//偏好设置//归档普通对象//联系人数据存储//协议与回调函数...
  7. 用友NC删除会计科目的前后台操作
  8. 程序员的量化交易之路(17)--Cointrader之Temporal实体(5)
  9. Python 中的 - 是什么意思
  10. 技术经理应该具备哪些方面的能力
  11. NAS 详细搭建方案 -安装OpenWrt/LEDE 软路由
  12. iPS细胞治疗糖尿病的研究
  13. 读《天才在左,疯子在右》01--偷取时间
  14. 『HDU 5745』La Vie en rose
  15. 电脑右键新建,少了office的几个图标,如:excel,word
  16. Kali Linux中Unable to locate package错误的解决方法2-1
  17. 什么是电子合同,如何签订电子合同?
  18. 应用组件的名字与已安装应用有冲突
  19. 淘宝购物如何找优惠券_淘宝上买衣服怎么省钱
  20. matlab怎么开始使用方法,matlab怎么使用,matlab基本使用方法

热门文章

  1. R语言使用psych包的fa函数对指定数据集进行因子分析(输入数据为相关性矩阵)、使用rotate参数指定进行斜交旋转提取因子、使用factor.plot函数可视化斜交旋转因子分析、并解读可视化图形
  2. pandas任取dataframe中的一个或者多个数据行(head、tail、loc、iloc),将抽取到的一个或者多个数据行复制N次形成新的dataframe
  3. pandas基于时序数据计算模型预测推理需要的统计数据(累计时间、长度变化、变化率、方差、均值、最大、最小等):范围内的统计量、变化率、获得数据集最后的几条数据的统计量、变化率、获得范围内的统计量
  4. python使用sklearn的PrecisionRecallDisplay来可视化PR曲线
  5. R语言对数正态分布分布函数Log Normal Distribution(dlnorm, plnorm, qlnorm rlnorm)实战
  6. 核逼近(Kernel Approximation)
  7. 机器学习调参与贝叶斯优化及其典型python实现hyperopt
  8. php统计键出现的次数,php统计数组元素出现的次数
  9. Windows下创建PXE网络安装Linux[Redhat AS5.5]IBM X3650
  10. Go语言学习之旅01--变量与数据