是什么是递归?-[all]-[编程理论]
递归是所有编程语言中,都会讨论到的一个问题。
Content Of Table
递归的通俗认识
编程领域的抽象
一个最简单的示例
一点总结
栈溢出问题
本示例的一点拓展说明
### 递归的通俗认识
编程是现实的抽象,这是能被应用到所有的编程概念的。
递归也是如此,其实递归,就是重复,循环, 我们大概上幼儿园的时候,其实就有过递归的概念。
![](https://img2018.cnblogs.com/blog/1735896/201912/1735896-20191220180001252-1957541256.png)
在一个故事中,不断的提到上一次讲过的故事
### 编程领域的抽象
我们知道,一个函数是可以调用另一个函数的,作为特例,如果函数调用了自己。那么就像故事中提到同样的故事一样。
我们把函数在运行的时候调用自己的情况,叫做递归。其实这样讲并不严谨,因为以上讲到的,实际只有递进,没有回归。回归是计算中的概念,我们可以大致理解为返回并销毁,以下说明。
### 一个最简单的示例
我们定义一个自调用的最简单的情况,定义一个cal函数,如下:
```javascript
//js
function cal(a){
return a + cal(a-1)
}
console.log(cal(3))
其执行过程如下:
<center>![](https://img2018.cnblogs.com/blog/1735896/201912/1735896-20191220225318405-1003795447.png)</center>
显然,这不是我们希望的结果,由于程序无条件的执行,所以该程序理论上将无止尽的递进下去。但是在计算机中,是不被允许的,文章末尾<ud>[栈溢出问题](#栈溢出问题)</ud>
现在,我们为了不让这个程序无止尽递进执行,我们需要给它加上一些条件,例如:
```javascript
//js
function cal(a){
if(a>0){
return a + cal(a-1)
}else{
return 0
}
}
console.log(cal(3))
我们给程序加了一些判断,我们判断了a这个参数,如果它大于0,我们就准许它递归。如果它等于0了,我们就直接通过return终止程序,并且返回0。实现回归
以上程序执行结果为6,正确。 它的实现功能是:3+2+1+0
### 一点总结
- 递归,简单的来说,就是一个方法自己调用自己的这么一个过程
- 递归递归,递:指的是“递进”,归:指的是“回归,返回”。 所以,一般递归方法中会有判断,能让方法有条件的执行,有递,就要有归 否则,只递不归就会造成栈溢出,导致程序崩溃。因此,我们需要有条件语句在合适的时候终止递归。
### 栈溢出问题
在程序中,调用函数,是需要有“代价”的,那就是,要占用一片叫做栈(Stack)的内存空间。
当调用函数时,数据需要存储到栈里,当函数运行结束的时候,这些数据会从栈里被取出。
所以,可想而知,如果调用了很多函数,但是这些函数都不返回,不被处理掉,栈就会被塞满,数据就没有地方放了。
这种情况,叫做栈溢出错误。
对于程序运行而言,这是致命的错误,因此程序会被操作系统强行终止。
例如,如果以上示例,没有设置条件判断,就会产生以下错误(js):
![](https://img2018.cnblogs.com/blog/1735896/201912/1735896-20191220232122561-673785687.png)
本示例的一点拓展说明
虽然本示例用到的是一个最简单的递归方法。
但是仅通过此方法,就可以实现各种等差数列的求和:
![](https://img2018.cnblogs.com/blog/1735896/201912/1735896-20191221003044280-1263729883.png)
如果是a+x呢?、 * ?、 / ? 、更复杂的数学公式?
仅通过这个一个示例我们就可以轻松的实现:
- 形如:1+3+5+7+···+(2n-1) 这种奇数项求和
- 形如:2+4+6+8+···+2n 这种偶数项求和
- 形如:1+2+3+4+5+6+···+n 这种累加
- 甚至形如: 11+8+5+2+0 这种奇偶求和
是什么是递归?-[all]-[编程理论]的更多相关文章
- Python并发编程理论篇
Python并发编程理论篇 前言 其实关于Python的并发编程是比较难写的一章,因为涉及到的知识很复杂并且理论偏多,所以在这里我尽量的用一些非常简明的语言来尽可能的将它描述清楚,在学习之前首先要记住 ...
- 如何编写高质量的 JS 函数(3) --函数式编程[理论篇]
本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/EWSqZuujHIRyx8Eb2SSidQ作者:杨昆 [编写高质量函数系列]中, <如何 ...
- T-SQL :编程理论 (一)
SQL代表结构化查询语言,是一种在关系数据库系统中查询和管理数据的标准语言.sql语句也有几个类别,包括定义语言(DDL),数据操作语言(DML),数据控制语言(DCL). DDL包括create,a ...
- AOP编程-理论篇
本节内容主要讲解AOP编程理念,包括概念讲解,使用AOP的优势,如何实现AOP,常见的实现AOP的方法. 1.AOP的概念 AOP是Aspect Oriented Programming的缩写,意思是 ...
- Socket编程理论
Socket理论 本地IP地址.本地端口号.外地IP地址.外地端口号组成一对套接字对. socket(套接字),就是 IP:端口号的形式. 一个完整的Socket有一个本地唯一的Socket号,由操作 ...
- JDBC编程理论知识(1)
1.SUN公司为统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC 2.JDBC全称为:Java Data Base Connectivity(java数据库连接),它主要由接口组 ...
- Mysql——JDBC编程 理论介绍
一.JDBC简介(来自俞琰--数据库老师) Java数据库编程主要使用JDBC技术.JDBC是一种用于执行SQL语句的Java API.它由一组用Java编写的类和接口组成.JDBC为开发人员提供了一 ...
- 多进程编程——理论讲解与 multiprocessing 模块
多进程编程 import os pid = os .fork() 功能 :创建新的进程 参数: 无 返回值 :失败返回一个负数 成功:在原有进程中返回新的进程的PID号 在新进程中返回为0* 子进程会 ...
- day38 并发编程(理论)
目录 一.操作系统发展史 二.多道技术 1 单核实现并发的效果 2 多道技术图解 3 多道技术重点 三.进程理论 1 必备知识点 2 进程调度 3 进程的三状态 4 两对重要概念 四.开启进程的两种方 ...
随机推荐
- 机器学习基础——简单易懂的K邻近算法,根据邻居“找自己”
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天的文章给大家分享机器学习领域非常简单的模型--KNN,也就是K Nearest Neighbours算法,翻译过来很简单,就是K最近邻居 ...
- Node.Js的热更新服务——supervisor
因为目前项目每次修改文件要看效果,必须重启服务:node app.js再进入浏览器看效果,很是麻烦.所幸的是有很多第三方的管理工具(supervisor,hotnode,forever,pm2等),当 ...
- python切片使用方法(超详细)
#切片:就是根据一个下标范围来获取一部分数据,切片通常结合字符串,列表,元组使用 # 为什么使用切片?因为下标只能获取一个数据,所以想要获取字符串或者列表当中一部分数据需要用切片. # 切片的语法格式 ...
- [C++入门篇]了解C++
前言 我是杨某人,点击右下方"+"一键关注我.如果你喜欢我的文章,那么拒绝白嫖行为.然后..请多来做客鸭. 如果你是已经入门的大佬,请滑到下方点个推荐再走. 我个人认为,博客有两种 ...
- Markdown For EditPlus插件发布(基于EditPlus快速编辑Markdonw文件,写作爱好的福音来啦)
详细介绍: Markdown For EditPlus插件使用说明 开发缘由 特点好处: 中文版使用说明 相关命令(输入字符敲空格自动输出): EditPlus常用快捷键: 相关教程: English ...
- 简说Python之IO
闺女,你在玩电脑什么游戏? 爸爸,我在玩植物大战僵尸呢. 闺女,你知道什么是输入输出设备吗? 爸爸,??? 你看,咱们的键盘和鼠标 ,就是可以控制那些植物的工具.这些发出指令的就是输入设备.咱们可以用 ...
- Vue2.0 【第一季】第4节 v-text & v-html
目录 Vue2.0 [第一季]第4节 v-text & v-html 第四节 v-text & v-html Vue2.0 [第一季]第4节 v-text & v-html 第 ...
- vue项目使用Vant框架Rem适配(postcss-pxtorem、lib-flexible )的安装使用
1.下载lib-flexible 使用的是vue-cli+webpack,通过npm来安装的 npm i lib-flexible --save 2.引入lib-flexible 在main.js中引 ...
- WINDOWS上JDK安装与环境变量设置
一.JDK安装 jdk版本:jdk1.8.0_144 下载链接:https://pan.baidu.com/s/1eS2bFhg 密码:e3q1 下载JDK后点击安装,可以根据需要修改JDK的安装目录 ...
- js 行走的小女孩 面向对象
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...