C语言讲义——函数递归
- 函数直接或间接调用自身
- 每次调用必须获得一些进展,进一步靠近目标
- 达到目标就不再调用自身
- 阅读递归函数不要纠缠于执行过程,而是相信递归函数会顺利完成任务
例:阶乘
0! =1(0 的阶乘定为1)
1! =1
2! =2*1=2
3! =3*2*1=6
n! = n × (n-1) ×…× 2 × 1
0! = 1
1! = 1
2! = 2
3! = 6
4! = 24
5! = 120
6! = 720
7! = 5040
8! = 40320
9! = 362880
10! = 3628800
不用递归
main() {
	int ret;
	int i,j;
	for(i=0; i<=10; i++) {
		ret = 1;
		for(j = i; j>1; j--) {
			ret = ret *j;
		}
		printf("%d! = %d\n",i, ret);
	}
}
使用递归
#include <stdio.h>
int factorial(int n) {
	if(n == 0) {
		return 1;
	}
	int ret = n*factorial(n-1);
	return ret;
}
main() {
	int i;
	for(i = 0; i<=10; i++) {
		int ret = factorial(i);
		printf("%d! = %d\n",i, ret);
	}
}

练习:斐波那契数列

C语言讲义——函数递归的更多相关文章
- [日常] Go语言圣经-函数递归习题
		练习 5.1: 修改findlinks代码中遍历n.FirstChild链表的部分,将循环调用visit,改成递归调用. 练习 5.2: 编写函数,记录在HTML树中出现的同名元素的次数. 练习 5. ... 
- C语言讲义——函数
		为实现特定目的而编写的一段可被调用的代码 简单地讲:函数就是一组语句,取了个名字 别名:子例程(routine)/方法(Method,一般面向对象的语言使用这个叫法) 函数的组成部分 以主函数为例: ... 
- c语言函数, 函数调用及函数递归
		1. 函数的定义: 返回值类型 函数名(形参列表) {函数体(函数的实现内容)}, 注意: 如果没有参数, 小括号也是必不可少的. 函数与函数之间可以嵌套调用(也就是在一个函数内部可以调用另外一个函 ... 
- C语言基础--函数
		函数概念: 1. C语言程序是由函数组成 2. 什么是函数? 函数就是一段具备特定功能的程序段 定义函数的目的: 定义函数的目的: 将一个功能封装以来方便复用 不使用函数的弊端: 1.重复代码太多, ... 
- 【C语言】函数和自定义函数
		函数,我之前也提到过一点点内容.其实函数是很好理解的,但是写起来又十分麻烦. 一. 函数引入 我们知道,C源程序是由函数组成的.请看下面的简单函数例子 #include <stdio.h ... 
- 函数:递归是神马 - 零基础入门学习Python022
		函数:递归是神马 让编程改变世界 Change the world by program 我们这节课的主题叫递归是神马,将通过小甲鱼带感的讲解,来告诉大家神马是递归!如果说优秀的程序员是伯乐,那么把递 ... 
- Python第七天   函数  函数参数   函数里的变量   函数返回值  多类型传值      函数递归调用   匿名函数   内置函数
		Python第七天 函数 函数参数 函数里的变量 函数返回值 多类型传值 函数递归调用 匿名函数 内置函数 目录 Pycharm使用技巧(转载) Python第一天 ... 
- [日常] Go语言圣经-函数多返回值习题
		Go语言圣经-函数多返回值1.在Go中,一个函数可以返回多个值2.许多标准库中的函数返回2个值,一个是期望得到的返回值,另一个是函数出错时的错误信息3.如果一个函数将所有的返回值都显示的变量名,那么该 ... 
- 【R】R语言常用函数
		R语言常用函数 基本 一.数据管理vector:向量 numeric:数值型向量 logical:逻辑型向量character:字符型向量 list:列表 data.frame:数据框c:连接为向量或 ... 
随机推荐
- OpenCV412+contrib+CUDA+cuDNN
			首先现在好软件(包含源码和官方编译好的库)和contrib源码包(对应版本怎么下载????) 软件: contirb包: 1.先把软件解压,在目录新建mybuild文件夹,用于输出保存自定义VS工程 ... 
- C1. Pokémon Army (easy version) 解析(DP)
			Codeforce 1420 C1. Pokémon Army (easy version) 解析(DP) 今天我們來看看CF1420C1 題目連結 題目 對於一個數列\(a\),選若干個數字,求al ... 
- 正则表达式小应用之对xml格式字符串每个字段加双引号
			通过Python对接口进行自动化后需要把xml格式的报文放到LoadRunner上进行压力测试,在pyCharm控制台打印出报文后,把报文放到LoadRunner中做了格式调整后,每个字段需要添加双引 ... 
- day78:luffy:前端对于token的认证&滑动验证码的实现
			目录 1.前端对于token的认证 2.滑动验证码 1.滑动验证码实现的原理 2.滑动验证码的代码实现 1.配置文件 2.前端实现:Login.vue 3.后端实现:改写jwt代码 1.前端对于tok ... 
- 09   Servlet中间服务  连接前段和后端
			import 导入 在当前类中使用外包中的类时使用 cookies 缓存 Alt + enter 提示快捷键 Servlet 服务 (连接前段和后端) Servlet本质就是Java类 Ja ... 
- JVM详解(二)-- 第2章 类加载器子系统
			一.JVM内存结构 1.1 内存结构---概略图 1.2 内存结构--详细图 二.类加载器子系统的作用 类加载器子系统负责从文件系统或网络中加载.Class文件,文件需要有特定的标识(cafe bab ... 
- 洛谷P6623——[省选联考 2020 A 卷] 树
			传送门:QAQQAQ 题意:自己看 思路:正解应该是线段树/trie树合并? 但是本蒟蒻啥也不会,就用了树上二次差分 (思路来源于https://www.luogu.com.cn/blog/dengy ... 
- 2.5远程仓的库使用-2.7Git别名
			2.5 远程仓库的使用 查看远程仓库 git remote # -v 选项会显示需要读写远程仓库使用的 Git 保存的简写与其对应的 URL 添加远程仓库 git remote add <sho ... 
- leetcode129valid-parentheses
			题目描述 给出一个仅包含字符'(',')','{','}','['和']',的字符串,判断给出的字符串是否是合法的括号序列 括号必须以正确的顺序关闭,"()"和"()[] ... 
- TCP 三次握手和四次挥手图解(有限状态机)
			传输控制协议(TCP,Transmission Control Protocol)是一种面向连接的.可靠的.基于字节流的传输层通信协议,由 IETF 的 RFC 793 定义,是为了在不可靠的互联网络 ... 
