趣学python编程 (四、数据结构和算法介绍)

news2025/1/9 17:02:07

数据结构和算法在编程中非常重要。数据结构是组织和存储数据的方式,而算法是解决问题的方法和步骤。你要挑战的蓝桥杯,实际也是在设计算法解决问题。其实各种编程语言都只是工具,而程序的核心=数据结构+算法。犹如练武,数据结构和算法是内功,各种编程语言都只是刀枪棍棒,根据需要在不同的场合选用顺手的兵器。

前言

翻遍了各种python书籍,要么是纯粹的知识点灌输,要么是面向小孩儿的图片和游戏任务太多,知识点太琐碎,不能让编程系统起来。(不是说那种方式不好,只是效果有限,可能得学好多年才有所悟)。这也是本系列教程到这里也没开始一行代码的原因。先有知识背景的介绍,后面的学习才能更有效。

鼓励我们的学生善于发问的习惯。学贵有疑,明代教育家朱熹有言:“学贵知疑,小疑则小进,大疑则大进。”,在学习过程中,有疑问、有困惑是正常的,甚至是必要的。不能有觉得自卑或害怕批评的顾虑。因为只有对某个知识点有疑问时,才会去深入研究,去寻找答案,这样才能真正理解和掌握。“读书无疑者须教有疑,有疑者却要无疑,这里方是长进。” ,语出《朱子语类·学五·读书法下》。

学python你不能只学python,你需要首先让了解下全貌,脑补下背景和基础,否则很容易“不识庐山真面目,只缘身在此山中”。(至少得补点计算机的历史和基础,毕竟初学者不像计算机专业的大学生,他们有操作系统,数据结构算法和编程语言等方面的基础课程,可以上来就讲python)。

就像写作文一样,如果才能写好作文?

你要写风,你就不能只写风。要写湖面的波纹,要写云朵向哪走,飞沙往哪飘,要写屋檐边悬挂的铃铛响,要写轻舟与竹筏的轻漾,要写人们不听话的衣角和发梢,写抓不住的气球。

你要写雪,就不能只写雪。要写凛冽,写皎洁,写天下万物的苍茫与凄切。要写北风卷地吹醒夜、寒冬腊月。写原驰蜡象,写山舞银蛇。写桥下冰初结,写陌上人行绝。写一支梅的孤傲与决绝,写千山鸟飞绝,万径人踪灭,直到最后,推敲思量,把你写进词里,白首不分离,相望鬓边初雪。

你要写月,就不能只写月。要写阴晴,写圆缺。写盈满清辉掩盖的疮痕和孤孑。要写林深鹿动,疏影横斜。也要写夜雪呼啸的刚劲哀绝。写一首松风解带、山涧琴声;再写一阙掬水弄香、古刹掩门。至此再搁笔,不提一字,满目皆是。

你要写雨,就不能只写雨。要写芭蕉,写落絮。写世人看不透的别离与相遇。写巴山之夜,写梅子黄时。写一叠纸的相思与残句。写黄昏窗外点滴声,似与梧桐耳语。再写僧庐阶前鬓已星,悲观总无情。直到最后,才陡然折笔,把你写进词的下半阙。已然只剩唏嘘。

你要写云,就不能只写云。要写自然、写随风。写天下人间的漂浮与乘空。要写衣裳花想容,拂槛露华浓。写落日熔金,人在何处。写一番情深不寿的苦留与无凭。写此后锦书休寄,悲痛使人愁。写行也思君,暮也思君。再写众鸟高飞尽,雪落芦烟直。直至终了,朝思西计提笔道是楚山秦山皆白云,白云处处长随君。

你要写夏,就不能只写夏天。要写炽热,要写蝉鸣。写世人看不透的憧憬和遇见。要写橙色黄昏晚风拂,夏夜猖狂。写蝉鸣正响,写晚风不凉。写满架蔷薇的浪漫和肆意。写河畔清风迎面吹,皎洁月色常伴。再写绿树浓荫十里荷花,悠悠夏日长。

你要写秋,就不能只写秋。要写思念和离愁,这人间诉不尽的相思和烦忧。要写寂寞无言独自上西楼,弯月如钩。写有暗香盈袖,写人比黄花瘦。写一轮月的期许与诉求。写濛濛细雨打芭蕉,写一片痴情付水东流。再写姑苏城外清寒古寺,钟声幽幽。

你要学python,就不能只学python,需了解点儿计算机的历史,计算机基础知识。需要有一定的计算机基础,包括数据结构、操作系统、计算机网络、数据库等。只有这样才能更好地掌握Python语言,并将其应用起来,这样学起来才更有效率。

数据结构和算法介绍

在编程中,数据结构和算法是非常重要的。“程序=数据结构+算法”,足见数据结构和算法的重要性。数据结构是程序的基础,它定义了数据的存储方式和操作方式。而算法是程序的逻辑和灵魂,它定义了程序如何处理数据以解决问题。一开始就要有数据结构和算法的概念,这在以后的编程中非常重要。

尽管关于数据结构和算法的知识单独一个拿出来讲,都够写一本书了,但是还是有必要提及一些。俗话说“师父领进门,修行在个人”,数据结构和算法其实一直贯穿在整个编程的过程中,有时你只是使用,不关注而已。

数据结构

数据结构是一种组织数据的方式,以便可以有效地进行访问、搜索和修改。不同的数据结构有不同的性能特点,例如,数组可以随机访问元素,链表可以高效地插入和删除元素,而二叉搜索树可以在log(n)时间内完成搜索。选择正确的数据结构可以极大地影响程序的效率和可读性。

后面要讲到的Python中的数组、字符串、列表、元组和字典其实都属于数据结构,它们可以用来存储和组织数据,并且每种类型都有自己独特的特点和用途。列表和元组属于线性数据结构,而字典则属于非线性数据结构。

线性数据结构是指数据元素之间存在一种线性关系的数据结构,即任意两个数据元素之间存在一对一的关系。

常见的线性数据结构有:线性表、栈、队列、双端队列、串(字符串)和链表。  

非线性数据结构是指数据元素之间不存在线性关系的数据结构,即任意两个数据元素之间可能存在多对一或一对多的关系。常见的非线性数据结构有:树、二叉树、堆、图。

线性数据结构的特点是元素之间存在一种线性关系,可以按照一定的次序访问或操作数据元素,但是插入和删除操作较为困难,效率较低。

非线性数据结构的特点是元素之间不存在明显的线性关系,可以表示一些复杂的层次结构和关系,但是访问和操作数据元素的顺序依赖于具体的操作路径,不够直观。在某些场景下,非线性数据结构的插入和删除操作更加高效。

- 数组(Array):用于存储和访问相同类型的数据元素的集合。

- 字符串(String):用于存储和操作文本数据的一种数据类型。

- 列表(List):用于存储和访问任意类型的数据元素的有序集合。

- 元组(Tuple):用于存储和访问任意类型的数据元素的有序集合,但元组是不可变的。

- 字典(Dictionary):用于存储和访问键值对数据的一种数据类型。

当然可以自定义数据结构啦!Python中可以通过类定义来创建自定义的数据结构。什么是类?什么是对象?这个对初学者可能一下子不容易理解,不过没关系,慢慢的用的多了自然会理解。这里先简单介绍下,有个初步的印象即可,后面用到了再讲解。

什么是类?

类是一种数据结构的抽象,对现实世界的抽象,它是一个模子,用于创建对象,它定义了对象的属性和方法。

什么是对象?

对象是类的实例,具有类定义的属性和方法。类是对象的蓝图,描述了对象的特征和行为。对象是类的具体实例,具有类的特征和行为的具体实现。

类和对象是面向对象编程的重要概念。通过类和对象,可以更好地组织和管理代码,提高代码的可复用性和可维护性。

类的属性是类的成员变量,用于存储类的相关信息,可以在类的任何方法中使用。而类的方法是类的成员函数,用于定义类的行为,可以访问和修改类的属性。类的属性和方法是类的构成要素,用于描述类的特征和行为。

通过汽车举例,讲一下什么是类,什么是对象:

当我们谈论汽车时,汽车就是一个类,它描述了一类具有相同特征和行为的对象(一种交通工具,有轮子、会跑、会鸣笛),但你不知道是哪种汽车,只知道大概它有哪些特征。但是光知道汽车,你肯定不能直接开啊,得具体到某一汽车实体才行。具体的某一辆汽车,比如我的汽车,就是汽车类的一个对象,它具有该类所定义的特征(变量如车速,剩余油量)和行为(函数如启动,停止,转弯)的具体实例。类是抽象的,对象是具体的。类是对象的模板,而对象是类的实例。

当我们谈论动物时,动物就是一个类,它描述了一类具有相同特征和行为的对象。而具体的某一只动物,比如我的宠物狗,就是该类的一个对象,它具有该类所定义的特征和行为的具体实例。类是抽象的,对象是具体的。类是对象的模板,而对象是类的实例。

在编程中,类和对象存在的意义是什么?

类和对象是面向对象编程的重要概念,当然你也可以不用它,直接面向过程编程即可。前面的一些简单编程任务,基本不涉及这一块儿,但是往后深入编程,类和对象是一定会用到的。

但是用他们是有好处的,它们对现实世界很好的模拟,提供了一种组织和管理代码的方法。类和对象的存在具有以下几个意义:

 1. 模块化:类和对象可以将程序划分为模块,每个模块都有自己的类和对象,从而降低程序的复杂性,提高代码的可维护性和可复用性。  

2. 抽象:类和对象可以将具体问题抽象为抽象的数据类型,隐藏内部实现细节,只暴露出必要的接口,从而降低程序的复杂性,提高代码的可读性和可理解性。  

3. 封装:类和对象可以将数据和函数封装在一起,形成一个独立的单位,保护数据不被外部随意访问和修改,从而提高程序的安全性和稳定性。  

4. 继承:类和对象可以通过继承建立类之间的关系,从而实现代码的共享和重用,减少代码的冗余,提高代码的可扩展性和可维护性。

总之,类和对象是面向对象编程的重要概念,它们可以提高代码的可维护性、可复用性、可扩展性、可读性、可理解性、安全性和稳定性,降低程序的复杂性,提高编程效率。

算法

算法也是编程中不可或缺的一部分,只是有时你可能没意识到它的存在。算法是一系列解决问题或完成特定任务的明确指令。你做的各种编程任务,其实都可以算做是在设计算法解决问题。

算法是一系列解决问题的清晰指令,旨在将输入映射为输出。通常算法用于执行计算、数据处理和自动推理等任务。算法可以用各种方式表示,包括自然语言、流程图、伪代码和计算机编程语言。算法的选择取决于问题的性质、所需的计算资源以及目标输出的形式。一些常见的算法示例包括排序算法(如冒泡排序和快速排序)、搜索算法(如线性搜索和二分搜索)以及加密算法(如对称密钥算法和公钥算法)。算法可以脱离代码单独存在,可以用各种方式表示,包括自然语言、流程图、伪代码和计算机编程语言。算法可以不依赖于任何具体的编程语言来存在。

比如给你出道题,从1加到100,你会怎么做?你的实现也可以称之为一个简单的算法。

常见的算法有哪些?

常见的算法包括排序算法(如冒泡排序、插入排序、快速排序)、搜索算法(如线性搜索、二分搜索)、加密算法(如对称密钥算法、公钥算法)、最短路径算法(如Dijkstra算法)、图算法(如深度优先搜索算法、广度优先搜索算法)等。

讲一个故事,斯坦福大学是怎么给学生讲二分查找算法的,上来就表演“撕书”。国外的老讲授讲课就是生动形象,拿查找一本书里的某个字来举例,问如何才能快速的找到想要的字?先把书翻开一半,结果没找到直接撕掉一半,然后再在另一半书中再翻开一半去找,直到找到为止。你猜在几千页厚厚的书中找到某个字仅需要几步?可能十几步就找到了,速度够快吧。采用的这种一次劈开一半,再从一半书中找到某个字的方法,就可以称之为算法。

总结

数据结构和算法是计算机科学的基础。理解数据结构和算法可以帮助程序员更好地理解程序的行为和性能,从而编写更高效、更可维护的代码。此外,数据结构和算法也是计算机科学中的核心概念,对于编写复杂的软件和解决现实世界的问题非常重要。

其他资源

引用链接

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1231010.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Zotero在word中插入带超链接的参考文献/交叉引用/跳转参考文献

Zotero以其丰富的插件而闻名,使用起来十分的带劲,最重要的是它是免费的、不卡顿,不像某专业软件。 然而Zotero在word插入参考文献时,无法为参考文献添加超链接,这是一个不得不提的遗憾。 不过,有大佬已经…

C语言——写一个函数,每调用一次这个函数,就会将num的值增加1

#define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h>void Add(int* p) {(*p); // 的优先级高于* } int main() {int num0;Add(&num);printf("第一次调用:num %d\n",num);Add(&num);printf("第二次调用:num %d\n",num);Add(&num);p…

如何客观看待通过线上性格测试来刷人的公司?

不论是校招&#xff0c;还是社招&#xff0c;我认为采用性格测评的目的&#xff0c;有两种情况&#xff1a; 1、应聘者多&#xff0c;减轻面试的压力 这种情况是最常见的&#xff0c;如果招不到人&#xff0c;应聘者少&#xff0c;我想HR是恨不得开车去接你过来面试&#xff…

Java 算法篇-链表的经典算法:判断回文链表、判断环链表与寻找环入口节点(“龟兔赛跑“算法实现)

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 链表的创建 2.0 判断回文链表说明 2.1 快慢指针方法 2.2 使用递归方式实现反转链表方法 2.3 实现判断回文链表 - 使用快慢指针与反转链表方法 3.0 判断环链表说明…

【数据结构初阶】双链表

双链表 1.双链表的实现1.1结口实现1.2申请结点1.3初始化双链表1.4打印双链表1.5尾插1.6尾删1.7头插1.8头删1.9计算大小1.10查找1.11pos位置插入1.12删除pos位置1.12删除双链表 全部码源 1.双链表的实现 1.1结口实现 #include<stdio.h> #include<stdlib.h> #inclu…

快速排序知识总结

快速排序思维导图&#xff1a; 快速排序算法模版&#xff1a; #include <iostream>using namespace std;const int N 1e5 10;int n; int q[N];void quick_sort(int q[], int l, int r) {if (l > r) return;int x q[(l r) / 2], i l - 1, j r 1;while (i < …

10 Redis的持久化

Redis支持RDB和AOF两种持久化机制 1、RDB(Redis DataBase) 是对命令的全量快照随着key的数量增大&#xff0c;那么写入磁盘的开销也会越来越大 2、RDB文件的生成是否会阻塞主线程 save: 使用save的方式会阻塞主线程&#xff0c;影响redis的性能 bgsave: 一般情况下不会阻塞…

J. Chem. Inf. Model. | 使用GRID描述符进行深度学习预测血脑屏障透过性

今天为大家介绍的是来自Simon Cross团队的一篇论文。深度学习方法能够自动从输入数据中提取相关特征并捕捉输入和输出之间的非线性关系。在这项工作中&#xff0c;作者提出了基于GRID的AI&#xff08;GrAId&#xff09;描述符&#xff0c;这是对GRID MIFs的简单修改&#xff0c…

Javaweb之Ajax的详细解析

1.1 Ajax介绍 1.1.1 Ajax概述 我们前端页面中的数据&#xff0c;如下图所示的表格中的学生信息&#xff0c;应该来自于后台&#xff0c;那么我们的后台和前端是互不影响的2个程序&#xff0c;那么我们前端应该如何从后台获取数据呢&#xff1f;因为是2个程序&#xff0c;所以…

记一次攻防实战渗透

经典开局一个登录框 由于漏洞应该还未修复。对于数据和相关网址打个码见谅一下 常规思路&#xff08;爆破&#xff09; 常规操作进行一波 尝试弱口令然后开始爆破 对于此种有验证码的爆破&#xff0c;可以借用一个bp插件。 captcha-killer-modified-jdk14.jar 具体使用我就…

读懂:“消费报销”模式新零售打法,适用连锁门店加盟的营销方案

读懂&#xff1a;“消费报销”模式新零售打法&#xff0c;适用连锁门店加盟的营销方案 引言&#xff1a;2023年的双十一已经落下帷幕&#xff0c;作为每年的经典电商促销节&#xff0c;今年已是第15个年头&#xff0c;但是今年各大电商平台却都是非常默契的&#xff0c;没有公布…

算法学习 day26

第二十六天 最大子数组和 53. 最大子数组和 - 力扣&#xff08;LeetCode&#xff09; 动态规划问题 class Solution {public int maxSubArray(int[] nums) {int len nums.length;int[] dp new int[len];dp[0] nums[0];int res dp[0];for(int i 1; i < len; i){dp[i] …

【封装UI组件库系列】搭建项目及准备工作

封装UI组件库系列第一篇搭建项目 前言 &#x1f31f;搭建项目 创建工程 基本结构 1.创建8个组件展示页面 ​ 2.配置路由文件router/index.js 3.页面布局 &#x1f31f;总结 前言 在前端开发中&#xff0c;大家可能已经用过各种各样的UI组件库了&#xff0c;现在市面上热…

ANSYS网格无关性检查

网格精度对应力结果存在很大的影响&#xff0c;有时候可以发现&#xff0c;随着网格精度逐渐提高&#xff0c;所求得的最大应力值逐渐趋于收敛。 默认网格&#xff1a; 从默认网格下计算出的应力云图可以发现&#xff0c;出现了的三处应力奇异点&#xff0c;此时算出的应力值是…

聊一聊go的单元测试

文章目录 概要一、测试框架1.1、testing1.2、stretchr/testify1.3、smartystreets/goconvey1.4、cweill/gotests 二、打桩和mock2.1、打桩2.2、mock2.2.1、mockgen 三、基准测试和模糊测试3.1、基准测试3.2、模糊测试 四、总结4.1、小结4.2、其他4.3、参考资料 概要 软件测试是…

vue3 ts vite 主题色功能

开发工具&#xff1a;vue3 ts vite 如上图&#xff0c;选择个颜色整个变化&#xff0c;如下图 默认主题为绿色 切换成其它色。 这里面的颜色块&#xff0c;你也可以给个取器色组件&#xff0c;可切换成任意色。切换时主要执行下方的方法&#xff0c;有兴趣可自己研究下。 /…

【运维篇】5.6 Redis server 主从复制配置

文章目录 0. 前言1. 配置方式步骤1: 准备硬件和网络步骤2: 安装Redis步骤3: 配置主服务器的Redis步骤4: 配置从服务器的Redis步骤5: 测试复制功能步骤6: 监控复制状态 2. 参考文档 0. 前言 在Redis运维篇的第5.6章节中&#xff0c;将讨论Redis服务器的主从复制配置。在开始之前…

根据nginx日志统计页面访问次数

静态页面部署在nginx上&#xff0c;页面只有查看下载功能。 需求是统计每条访问次数和下载次数&#xff0c;根据日志分析写了一个shell脚本&#xff0c;触发脚本后生成一个html可以远程查看统计的数量。 #!/bin/bash # nginx日志文件路径 LOG_FILE"/usr/local/nginx/l…

vue安装three.js并创建第一个入门场景

vue安装three.js&#xff0c;并创建第一个入门场景 安装three.js npm install --save three引入three.js import * as THREE from threethree.js结构 three.js坐标 创建一个场景 scene场景&#xff0c;camera相机&#xff0c;renderer渲染器 创建一个场景 this.scene new T…

B站短视频如何去水印?一键解析下载B站视频!

在浏览B站视频时&#xff0c;我们有时会遇到带有水印的场景。这些水印可能会干扰我们对视频内容的观看体验&#xff0c;特别是在全屏观看时。此外&#xff0c;当我们想要保存或分享这些视频时&#xff0c;水印也会成为一种障碍。因此&#xff0c;去除水印的需求就变得非常迫切。…