Python数据结构与算法(2)--算法分析

本文探讨了算法分析的重要性,强调了计算资源的使用效率,介绍了大O表示法作为衡量算法时间复杂度的标准。通过Python中的time模块展示了如何测量程序运行时间。接着,详细阐述了大O表示法的概念,并列举了一些常见数量级函数。最后,对比了Python列表和字典在不同操作下的性能,揭示了字典在查找操作上的优势。
摘要由CSDN通过智能技术生成

算法分析

  • 算法是对问题解决的分步描述
  • 程序则是采用某种编程语言实现的算法, 同一个算法通过不同的程序员采用不同的编程语言,能产生很多程序
  • 算法分析:主要就是从计算资源消耗的角度来评判和比较算法(更高效利用计算资源,或者更少占用计算资源的算法,就是好算法)
  • 计算资源指标
    一种是算法解决问题过程中需要的存储空间或内存(但存储空间受到问题自身数据规模的变化影响要区分哪些存储空间是问题本身描述所需,哪些是算法占用,不容易)
    另一种是算法的执行时间(我们可以对程序进行实际运行测试,获得真实的运行时间)
  • Python中有一个time模块,可以获取计
    算机系统当前时间(在算法开始前和结束后分别记录系统时间,做差即可得到运行时间)
import time
start = time.time()
...
end = time.time()
yunxingtime = end - start
  • 同一个算法,采用不同的编程语言编写, 放在不同的机器上运行,得到的运行时间 会不一样,有时候会大不一样.我们需要更好的方法来衡量算法运行时间

大O表示法

  • 算法时间度量指标
    ❖ 一个算法所实施的操作数量或步骤数可作为独立于具体程序/机器的度量指标。需要一种通用的基本操作来作为运行步骤的计量单位
    ❖ 赋值语句是一个合适的选择
    一条赋值语句同时包含了(表达式)计算和(变量)存储两个基本资源仔细观察程序设计语言特性,除了与计算资源无关的定义语句外,主要就是三种控制流语句和赋值语句&#x
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

D之光

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值