python数据结构和算法

前面系统地学习了python相关的基础知识,接下来,我们将继续学习python的数据结构和算法。 

我们知道,程序=数据结构+算法,那么,什么是数据结构,有什么是算法呢?如何系统的学习数据结构和算法呢?数据结构和算法在计算机世界中的作用如下图所示:

图片

Part.1  为什么要学习数据结构和算法?

遇到一个实际问题,需要解决两个事情:

(1)问题涉及到哪些数据信息;

(2) 用什么方法策略解决问题。

前者是数据结构,后者是算法。数据是一切能输入到计算机的信息总和,结构是指数据之间的关系,数据结构就是将数据及其之间的关系有效地存储在计算机中。如何将数据中的问题存储到计算机中,使其变得可用,成为有组织有效的可用信息,即为数据结构的任务。数据结构由逻辑结构,存储结构和运算三部分组成。

图片

当面对问题时,如何解决,即解决方法和步骤,即为算法。算法是指对特定问题求解步骤的一种描述,说白了就是解决问题的方法策略。算法是整个程序的灵魂,我们在处理问题时,算法就是解空间和问题空间的桥梁。

遇到一个实际问题,充分利用所学的数据结构,将数据及其之间的关系有效地存储在计算机中,然后选择合适的算法策略,并用程序高效实现。这就是N.Wirth教授所说的:数据结构+算法=程序。

以编程为例:
 编程好比是一辆汽车,而数据结构和算法是汽车内部的变速箱。一个开车的人不懂变速箱的原理也是能开车的,同理一个不懂数据结构和算法的人也能编程。但是如果一个开车的人懂变速箱的原理,比如降低速度来获得更大的牵引力,或者通过降低牵引力来获得更快的行驶速度。那么爬坡时使用1档,便可以获得更大的牵引力;下坡时便使用低档限制车的行驶速度。

回到编程而言,比如将一个班级的学生名字要临时存储在内存中,你会选择什么数据结构来存储,数组还是ArrayList,或者HashSet,或者别的数据结构。如果不懂数据结构的,可能随便选择一个容器来存储,也能完成所有的功能,但是后期如果随着学生数据量的增多,随便选择的数据结构肯定会存在性能问题,而一个懂数据结构和算法的人

  • 5
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python提供了许多内置的数据结构算法来处理不同类型的问题。以下是一些常见的Python数据结构算法: 1. 列表(List):列表是一种有序的可变容器,可以存储不同类型的数据。它支持索引访问、添加、删除和修改元素。列表还提供了一些常用的方法,如排序、反转等。 2. 元组(Tuple):元组是一种有序的不可变容器,类似于列表。与列表不同的是,元组的元素不能修改。元组通常用于存储不可变的数据。 3. 字典(Dictionary):字典是一种无序的可变容器,存储键值对(key-value)映射关系。字典可以通过键来快速访问和修改对应的值,是非常常用的数据结构之一。 4. 集合(Set):集合是一种无序的不重复元素的集合。它支持集合间的并、交、差等操作,还提供了一些常用的方法,如添加、删除元素等。 5. 栈(Stack):栈是一种后进先出(LIFO)的数据结构。在Python中,可以使用列表来模拟栈的行为,通过append()和pop()方法实现元素的入栈和出栈。 6. 队列(Queue):队列是一种先进先出(FIFO)的数据结构。可以使用列表或者collections模块中的deque来实现队列的功能。 在算法方面,Python提供了许多常用的算法数据结构的实现,如排序算法(如快速排序、归并排序)、搜索算法(如二分查找、广度优先搜索、深度优先搜索)等。此外,Python还提供了一些内置模块,如heapq、collections等,用于实现高效的数据结构算法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值