python算法

第一章 算法

一系列解决单个或多个问题,或有执行计算机功能的命令集合。人类在解决复杂问题时所采用的一系列特定的方法,即为算法。

算法与程序的区别

程序指一组计算机能识别和执行,并有一定功能的指令。程序是以计算机能理解的各式各样的编程语言编写而成,而算法是可以通过编程语言、图绘、口述等人能够理解的方式描述的。

算法作为方法,有正确、不正确、高效、低效之分。对算法至关重要的不止有正确性,还有效率。评判算法是否高效,可以用时间复杂度和空间复杂度丈量

时间复杂度

高级语言编写的程序运行时间主要取决入三个因素:算法的方法、策略;问题的输入规模;计算机执行命令的速度。问题的输入规模是客观的,除了计算机执行指令速度依靠性能提升,改进算法的策略是至关重要的。

当输入规模极为庞大时,时间复杂度的差距能使计算机运算的效率提升多个数量级。

空间复杂度

一个算法在计算机存储器上所占用的存储空间,包括算法本身所占用的存储空间,算法的输入、输出数据所占用的存储空间,算法在运行过程中临时占用的储存空间三个方面。空间复杂度是对一个算法所需存储空间的量度。

时间复杂度和空间复杂度往往相互制约、相互影响。在解决同一问题时,当追求降低时间复杂度时,可能会不可避免提高空间复杂度,占用较多储存空间;反之,降低空间复杂度时,可能提高时间复杂度,导致占用较长的运行时间。

设计算法的同时,要综合考虑算法的各种性能,从而有效提高效率。

算法的应用

算法的应用无处不在,小到排序问题,大到神经网络和深度学习,无论现实问题或虚拟问题,都很容易找到算法的影子。如:

深度学习

人类基因工程

搜索引擎和网络爬虫

python算法的优势

使用python学习算法,最大的优势就是可以看到复杂的算法怎样一步步从基本的语言机制实现出来。

第二章 排序算法

插入排序

​​​​​​​

相关推荐
ponponon5 分钟前
时代的眼泪,nameko 和 eventlet 停止维护后的项目自救,升级和替代之路
python
Flittly5 分钟前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(5)Skills (技能加载)
python·agent
敏编程18 分钟前
一天一个Python库:pyarrow - 大规模数据处理的利器
python
Flittly2 小时前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(4)Subagents (子智能体)
python·agent
CoovallyAIHub2 小时前
181小时视频丢给GPT-5,准确率只有15%——南大联合NVIDIA等五校发布多模态终身理解数据集
深度学习·算法·计算机视觉
CoovallyAIHub3 小时前
CVPR 2026 | GS-CLIP:3D几何先验+双流视觉融合,零样本工业缺陷检测新SOTA,四大3D工业数据集全面领先!
深度学习·算法·计算机视觉
有意义5 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
用户726876103376 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect7 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
明月_清风9 小时前
Python 装饰器前传:如果不懂“闭包”,你只是在复刻代码
后端·python