• 慕课网首页
  • 免费课
  • 实战课
  • 体系课
  • 发现
    评价 教程 专栏 手记
  • 商业合作
    企业服务 讲师入驻
搜索

热搜

最近搜索 清空

我的购物车

已加入门课程

购物车里空空如也

快去这里选购你中意的课程

实战课

体系课

我的订单中心
去购物车
  • 登录 / 注册
  • 新人专属0元礼包 | 查看
抱歉,未找到你想要查询的结果
全部开发者教程

Python 算法入门教程

算法概念简介
什么是算法?
排序算法
冒泡排序 插入排序 选择排序 希尔排序 快速排序
递归算法
递归算法介绍 递归算法实战
动态规划算法
动态规划算法介绍 动态规划算法实战
贪心算法
贪心算法介绍 简单难度贪心算法实战 复杂难度贪心算法实战
分治算法
分治算法介绍 分治算法实战
  • 前端开发

    JavaScript

    JavaScript 入门教程

    本教程带你从初级到高级全面掌握 Javascript 的使用方法

    TypeScript 入门教程

    这是一个很好的简单课程,只需2小时你就可以学习TypeScript基础知识。

    Vue 入门教程

    本教程带您从零开始学习 Vue 框架的使用,让您轻松应对 Vue 项目的开发。

    Ajax 入门教程

    本教程涵盖Ajax的实现原理,及Ajax封装,最后是框架实现方法。

    ES6-10 入门教程

    对比 ES5 进行学习 ES6+,理解 ES6+ 语法背后的思想

    Yarn 入门教程

    Yarn得相关基础知识和高级进阶

    ECharts 入门教程

    从零开始学习 ECharts ,掌握 ECharts 核心内容

    HTML & CSS

    CSS3 入门教程

    本课程从盒模型、文字、颜色、过渡、动画、布局、伪类等方面介绍 CSS3 的使用。

    雪碧图入门教程

    本文详细介绍了雪碧图的由来历史以及各种使用方式

    移动端布局教程

    由于移动互联网的兴起,移动端项目占据了很大一部分比重,本章将详细讲解几种常见布局

    Html5 入门教程

    最新一代的HTML标准,增加了许多实用的特性

    Sass 入门教程

    前端项目中 Sass 的快速入门教程

    HTML 入门教程

    从零讲解 HTML,掌握基础 HTML 知识内容

    canvas 入门教程

    本教程带你从初级到高级全面掌握canvas的使用方法

    uni-app 入门教程

    从零开始学习 uni-app 框架,轻松上手应用开发

  • 服务端相关

    服务器

    Nginx 入门教程

    本教程使您掌握 Nginx 安装、配置、核心模块的详解、实际使用的能力。

    HTTP 入门教程

    从协议原理开始到 Web 服务器以及 Web 安全一网打尽

    Docker 入门教程

    从 Docker 的基础概念开始,从实际问题入手带你学习 Docker

    Shell 入门教程

    本教程由浅入深,系统性的讲解Linux Shell脚本编程。

    Linux 入门教程

    本教程从安装 Linux 开始,囊括 Linux 基础命令操作以及进阶系统管理

    开发工具

    Gradle 入门教程

    本教程使您掌握实际使用gradle进行项目构建、测试、打包、发布的能力。

    Vim 编辑器教程

    课程主要讲解Vim的安装配置,四种模式、基本操作,以及包管理工具和寄存器等内容。

    RESTful 规范教程

    本教程从什么是 REST 开始带你领略 Web 开发中无处不在的规范

    Dreamweaver 教程

    DW 是一款同时具有网页制作和网页管理功能的网站开发工具,可以快速进行网站建设

    Markdown 入门教程

    本课程涵盖 Markdown 的基本及扩展语法。

    Maven 入门教程

    从最基础的安装 Maven 开始到 Maven 在开发中的实际应用

    Eclipse 编辑器教程

    本教程从Eclipse安装开始带你轻松掌握Eclipse常用开发技巧

    GitHub 入门教程

    本教程带你轻松掌握最实用的 GitHub 知识

    Android Studio 编辑器教程

    Android Studio 编程技巧一网打尽

    PyCharm 编辑器教程

    工作经常用到的 PyCharm 编辑器使用技巧一网打尽

    Sublime Text 使用教程

    花里胡哨展示sublime编辑器的各种功能

    Postman 教程

    Postman 由Google 开发用来做接口请求测试,前后端开发人员都可以使用

    Git入门教程

    从入门到精通。

    热门服务端语言

    C 语言入门教程

    本教程从语法基础、进阶知识等各方面详解 C 语言。

    Go 入门教程

    本教程从 Go 语言的基本语法掌握到进阶编程实践

    Kotlin 教程

    从 Kotlin 的基础语法到高级特性一网打尽

    Ruby 入门教程

    本教程从 Ruby 的各种对象开始学习到 Ruby 的实际使用

    ThinkPHP 入门教程

    本教程主要讲解 ThinkPHP 框架如何上手开发应用

  • Java

    基础应用

    Java 入门教程

    深入浅出讲解 Java 语言基础知识,带你入门 Java 语言

    Android 入门教程

    为你解析最实用的 Android 技术,让你平滑上手,顺利进阶,为开发保驾护航

    算法入门教程

    分析讲解常见算法的思想及使用

    数据结构入门教程

    通俗易懂的带你了解 Java 数据结构

    Lambda 表达式教程

    本教程展现了Lambda表达式的基础语法以及在程序中的应用

    Java 并发原理入门教程

    本教程为Java并发原理入门教程,在Java程序开发中占据着举足轻重的地位

    设计模式入门教程

    带你分析最常见的九个设计模式

    Java并发工具

    本课程简洁明了展示最基本的并发工具类相关概念及应用方法。

    JVM 入门教程

    JVM 入门教程,对JVM结构进行分模块讲解,简单易懂。

    RabbitMQ 入门教程

    超系统的RabbitMQ基础知识课程,你还在等什么?

    网络编程入门教程

    Java 网络编程核心要点详解

    后端通用面试教程

    带你系统梳理后端高频面试题,轻松丰富你的校招&社招阶段

    框架应用

    Spring Boot 入门教程

    循序渐进讲解 Spring Boot 企业级应用开发

    Spring 入门教程

    通俗易懂 渐进式讲解 Spring 企业级开发应用

    Hibernate 入门教程

    由浅入深讲解 Hibernate 企业级 JDBC 应用框架

    MyBatis 入门教程

    本教程整理出“百分之二十”的知识,帮你办到“百分之八十”事情

    Spring MVC 入门教程

    通俗易懂讲解 Spring MVC 框架应用

    Swagger 入门教程

    本课程以图文并茂的方式带你学习 Swagger 核心知识和应用剖析

    Zookeeper 入门教程

    由浅入深的 学习 ZooKeeper 的基本使用以及高级使用

    Netty 教程

    由浅入深的讲解 Netty 的核心知识体系,快速上手使用和理解 Netty

    Spring Security

    本课程涵盖了 Spring Security 框架的基本原理和集成方法

    微服务

    Spring Cloud Hystrix

    系统介绍 Hystrix 支持特性与实际应用场景实战

  • Python

    基础应用

    Python 入门语法教程

    本教程带你从 Python 的基础语法开始学习 Python。

    Python 原生爬虫教程

    本教程从爬虫基础知识到进阶技巧到实际应用。

    Python 进阶应用教程

    本教程涵盖 Python 的面向对象、标准库解析、异常处理直至最后的领域应用

    Python 算法入门教程

    用 Python 代码实现常用算法并汲取算法核心思想。

    进阶方向应用

    Django 入门教程

    从 Web 基础到 Django 框架的实际开发应用

    Flask 框架教程

    Flask 框架快速入门实现一个 TodoList 功能

    NumPy 入门教程

    本教程从基础的数据类型开始到 NumPy 的高级应用一网打尽

    Scrapy 入门教程

    从爬虫基础开始到使用 Scrapy 框架抓取各大网站数据

    TensorFlow 入门教程

    通过本教程对 TensorFlow 框架快速入门

    Python 办公自动化教程

    本教程带你使用Python快速操作Excel、Word、PPT,处理各种文件

    Pandas 入门教程

    本教程从基础的数据类型开始到 Pandas 的高级应用一-网打尽

  • 数据库

    MySQL

    MySQL 入门教程

    本教程主要讲解 MySQL 增删改查等基础操作

    SQL 入门教程

    本教程讲解使用 SQL 访问和处理数据系统中的数据的方法。

    MySQL 进阶教程

    那些你还不理解的 MySQL 高阶特性一网打尽

首页 慕课教程 Python 算法入门教程 Python 算法入门教程 什么是算法?
沈无奇 · 更新于 2020-12-29

冒泡排序

下一节

什么是算法?

1. 什么是算法

说实话,这个问题确实比较难以回答,我们先来看下百度百科对算法的定义:

算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制

简单点说算法就是解决一个问题的步骤或者方法。比如针对去上班这个问题,我们的步骤是这样:

首先是出门走路到地铁站,然后坐地铁到里公司最近的地铁口下,最后走路到公司。这样一个过程,可以称之为完成这个上班任务的一个算法。但是很明显,去上班的算法有很多种,并不止坐地铁这一种,我们可以打的去公司、坐公交去公司等等,这样不同的步骤也对应着不同的算法。这些方式有好又有坏,有快也有慢,同样算法也是一样有好有坏有快有慢的。同一个问题,有多种解决方法,也就是多种算法,不同的算法之间也会好坏之分。

但是不管算法如何定义,它一定要具备以下五个特征才能称之为算法:

  • 有穷性:算法必须能在有限步骤之后终止。无穷无尽执行下去,那根本不是解决问题的办法,也就不能称之为解决该问题的方法;
  • 确切性:算法的每一步必须要有确定的含义;
  • 输入项:算法需要有输入或者说初始条件。比如我们上班的算法,我们的初始条件就是从家出发;
  • 输出项:算法必须要有一个或者多个输出。比如我们上班的算法,输出项就是顺利到达公司;
  • 可行性:算法必须是可以实现的步骤。那种天马行空、无法实现的方法就不能称之为算法了。如果坐着宇宙飞碟去上班,这显然不切实际,当然也就不能成为之上班的一个算法了。

2. 为什么要学习算法

有人问在大部分的工作场景下我们都用不到算法,那么我们为什么还要学习算法呢?首先,需要明确以下几个问题:

  • 工作中用不到并不代表工作中没有用到;
  • 工作中不常用并不代表面试不常考;

学 Java 的同学几乎天天都在用 HashMap 吧?但是大家有思考过存储在 HashMap 中 key 和 value 值是究竟用什么数据结构存储的?当使用 get() 方法查找 value 时用的什么算法?

但是我们一般是不会考虑这种问题的,因为这些工作都由编程语言给我们已经封装好了,我们只需要调用,调用,再调用!

那么对于 Python 也是一样的,我们用的 dict 等类型,它背后都是 Python 解释器给我们做了大量工作,实现了各种各样复杂的算法,给我们的使用带来了极大的方便,也导致我们大部分程序员似乎在工作中几乎看不到算法的应用?

但是,不要忘了,我们是要追求进步的,如果你只是满足于调用各种 API 和方法来完成工作的话这个教程对你的意义不大。不过总会有现有的方法满足不了的业务场景,到那时候你该怎么办呢?

此外,算法同样是大厂最喜欢拿来考察候选人员能力的一个方式。社招中最喜欢考察算法编程能力公司的当属今日头条,许多国外的互联网公司如微软、Facebook 等甚至会让你直接手写代码。

除此以外,掌握一定的算法基础有以下几个好处:

  • 锻炼自己的思维和编程能力:保持解决问题的能力,这在工作中也是非常重要的一项技能;
  • 在面试中存在一定竞争力:优秀的编程者往往都是被大厂争夺的对象;
  • 在学习一些编程语言源码或者操作系统源码时会有深刻体会;

3. 如何学习算法?

学习基础算法的方法也很简单,就是刷题、刷题、理解后再刷题。刷题网站最出名的当属 leetcode,接下来是国内知名的就是牛客网了。如果对自己要求高,可以考虑刷 ACM 编程题,比较有名的有 POJ、ZOJ。当你能独立刷完上面的题目时,你已经是一名非常厉害的算法高手了,不过刷题也会耗费大量的业余时间,要懂得适可而止,享受生活。

4. 算法的评价标准

一个算法优劣的评价标准主要有两个:时间复杂度和空间复杂度。

4.1 时间复杂度

程序的运行时间往往有多方面因素综合决定,即使是同一种算法,不同的输入对应的运行时间可能也不相同。为针对运行时间建立一种可行、可信的评估标准,我们往往考虑输入数据的规模,这是最关键的因素。

通常情况下,问题的规模越接近,相应的计算成本也会很接近;而随着问题的规模扩大,相应的执行时间也会加长。因此,随着输入规模的扩大,算法的执行时间将如何增长,缓慢增长?线性增长,还是指数级增长?我们可以将算法的执行时间和问题的规模相互映射,得到了一个关于输入规模的函数,这个就可以称为该算法的时间复杂度。

4.2 空间复杂度

空间复杂度类似,我们将问题的规模和算法所需的存储空间一一映射,得到的函数称之为空间复杂度。就目前业界而言,由于存储本身的廉价性,算法工程师们大多将算法的优化集中在时间复杂度上,所以往往将时间复杂度当做衡量一个算法好坏的标准。当然时间复杂度低且空间复杂度也低的算法是最好的选择,但是往往二者不能得兼,很多问题也需要具体情况具体分析。

5. 本教程学习基础

本教程只需要简单的 Python 基础即可,没有其他的任何要求。主要是能理解一些解决问题的方法,比如递归、动态规划,需要一些抽象的思考能力。

6. 小结

今天我们简单介绍了下算法的概念以及为什么要学习算法进行了介绍。最后讨论了下算法的一般评价标准,主要是通过时间复杂度和空间复杂度进行衡量。今天的算法介绍就到这里了,下一节就开始算法实战以及相应的编程训练了,祝大家学习愉快。

  • 划线
  • 写笔记
  • 复制

0/1000

 

下一节

冒泡排序

我要提出意见反馈
· 最近更新于 请填写更新时间
使用手机查看
最近更新
向你推荐
更多
索引目录
什么是算法?
1. 什么是算法
2. 为什么要学习算法
3. 如何学习算法?
4. 算法的评价标准
4.1 时间复杂度
4.2 空间复杂度
5. 本教程学习基础
6. 小结
意见反馈 收藏教程 标记书签
使用 Ctrl+D 可将网站添加到书签
  • 企业服务
  • 网站地图
  • 网站首页
  • 关于我们
  • 联系我们
  • 讲师招募
  • 帮助中心
  • 意见反馈
  • 代码托管

Copyright© 2025 imooc.com All Rights Reserved | 京ICP备12003892号-11 京公网安备11010802030151号

微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

返回顶部