美文网首页
数学和算法

数学和算法

作者: 风吹燕尾 | 来源:发表于2021-01-31 14:38 被阅读0次

算法是解决某类问题的统一范式,如果你刚接触它,你可以类比成你数学中的各种公式或定理,基于这些公式我们可以解决相关的一类问题,数学中定理和公式大致也是如此。不过我们做数学题时,虽然有公式定理,但是问题都是变形过的,无法直接套用,算法也是一样的道理,所以从数学的角度去看待算法,你会很受启发。

很多人会把算法看成是一个人编程能力的体现,因为逻辑思考能力好的人编程应该也不会差。不过在我看来,不管是计算机算法还是编程,更多的是人对事物抽象能力的体现。

一个人算法好,不一定能写出好的程序,但是一个人如果抽象能力好,肯定更容易写出好程序。

但为什么数学好的人普遍编程都能学得很好,因为TA们比其他人更擅长理解、抽象和转化范式。

我们以一个递归算法举例

在数学和计算机科学中,递归指由一种(或多种)简单的基本情况定义的一类对象或方法,并规定其他所有情况都能被还原为其基本情况。
这是递归的正式定义,是不是觉得很像数学课本里的那些定理。接下来我们就按照以前学数学定理一样来学习递归。

定义已经有了,但是好像看的不是很明白,说的太官方了。所以我们需要用更朴实的语言描述出来:一种通过重复将问题分解为同类的子问题而解决问题的方法。

接下来我们会看看有没有公式,很可惜,递归没有像a^{2} + b^{2}= c^{2}这种公式,但是不要紧,没有公式,有形式,从形式我们可以推导出范式,比较经典就是斐波那契数列算法

function fibonacci(number) {
    if (number <= 2) {
        return 1;
    }
    return fibonacci(number-1) + fibonacci(number - 2)
}

同理,我们还能想到很多的形式,比如阶乘、汉诺塔......

从这些形式中我们好像慢慢找到了感觉,我们发现了递归算法两个要素:
• 调用自身
• 能跳出循环

学到了这些,我们基本可以去用递归解决问题了。想想学数学时你时怎么做的,学完后你通常会做大量与之相关的习题,这些题很多都是公式的变形和巧妙应用,之后你对这类题型便无所畏惧了。如果遵循这种思路学习,算法应该不会很差。

不过受数学的启发,还发想到另外一种方法:你不仅会用这个公式,你还能够反向构造出用到这个公式的问题、场景,这是一种很难,但是也很有效的方法。从解题人到出题人,从简单练习向高级练习的跨越。具备反向思考和构造的能力,才能真正实现融汇贯通。

相关文章

  • 数学和算法

    算法是解决某类问题的统一范式,如果你刚接触它,你可以类比成你数学中的各种公式或定理,基于这些公式我们可以解决相关的...

  • 机器学习4:局部加权回归

    参数学习算法,非参数学习算法 参数学习算法,用固定的明确的参数进行数据的拟合。比如线性回归。非参数学习算法,使用的...

  • 算法

    说起算法,相信大家普遍都听过数学算法,例如:口算,心算等,这些都属于数学算法。不过,今天给大家介绍的算法不是数学算...

  • C语言必学的12个排序算法:归并排序(第8篇)

    题外话很多童鞋感受算法比较难度,的确,算法其实和C语言本身关系不大,算法是计算机科学家利用丰富的数学和算法设计知识...

  • 一节有趣的数学课

    今天上午上数学课的时候,数学老师给我们讲四则运算的定义和简便算法。为了让我们更容易理解和掌握“简便算法”,老...

  • 从0到1学习区块链5-密码学

    区块链中主要用到了哈希算法和非对称加密。1、哈希算法(hash)哈希算法是一种数学函数算法。又叫散列算法,他是一种...

  • 哈希里的数学

    哈希里的数学 【本文由赞我(zaneds.com)独家冠名】 哈希算法,是由数学算法的构成的,这毋容置疑。什么算法...

  • 杭州7月python大数据机器学习高级工程师实战研讨会

    课程介绍 本课程特点是从数学层面推导最经典的机器学习算法,以及每种算法的示例和代码实现(Python)、如何做算法...

  • 02-21:LR算法

    LR算法 回头看LR算法真是异常简单啊 但是算法背后的数学原理想讲清楚也不容易 LR算法可以解决分类和回归问题 整...

  • 2021-11-30 400. 第 N 位数字

    最烦这种纯粹的数学题,数学本就不好的我瑟瑟发抖,就是纯粹的数学算法,搞清楚题意和理解就行。 java版本:

网友评论

      本文标题:数学和算法

      本文链接:https://www.haomeiwen.com/subject/prlrtltx.html