C语言教程
- 第1节:C语言 简介
- 第2节:C语言 环境设置
- 第3节:C语言 程序结构
- 第4节:C语言 基本语法
- 第5节:C语言 数据类型
- 第6节:C语言 变量
- 第7节:C语言 常量
- 第8节:C语言 存储类
- 第9节:C语言 运算符
- 第10节:C语言 判断
- 第11节:C语言 循环
- 第12节:C语言 函数
- 第13节:C语言 作用域规则
- 第14节:C语言 数组
- 第15节:C语言 指针
- 第16节:C语言 字符串
- 第17节:C语言 结构体
- 第18节:C语言 共用体
- 第19节:C语言 位域
- 第20节:C语言 typedef
- 第21节:C语言 文件读写
- 第22节:C语言 预处理器
- 第23节:C语言 头文件
- 第24节:C语言 强制类型转换
- 第25节:C语言 错误处理
- 第26节:C语言 递归
- 第27节:C语言 可变参数
- 第28节:C语言 内存管理
- 第29节:C语言 命令行参数
- 第30节:C语言 标准库 – <assert.h>
- 第31节:C语言 标准库 – <ctype.h>
- 第32节:C语言 标准库 – <errno.h>
- 第33节:C语言 标准库 – <float.h>
- 第34节:C语言 标准库 – <limits.h>
- 第35节:C语言 标准库 – <locale.h>
- 第36节:C语言 标准库 – <math.h>
- 第37节:C语言 标准库 – <setjmp.h>
- 第38节:C语言 标准库 – <signal.h>
- 第39节:C语言 标准库 – <stdarg.h>
- 第40节:C语言 标准库 – <stddef.h>
- 第41节:C语言 标准库 – <stdio.h>
- 第42节:C语言 标准库 – <stdlib.h>
- 第43节:C语言 标准库 – <string.h>
- 第44节:C语言 标准库 – <time.h>
C语言 递归
递归是以自相似的方式重复项目的处理过程。同样地,在编程语言中,在函数内部调用函数自身,称为递归调用。如下:
void recursion(){
recursion(); /* 函数调用自身 */
}
int main(){
recursion();
}
C 语言支持递归,即,一个函数可以调用自身。但在使用递归时,程序员需要注意定义一个从函数退出的条件,否则会进入无限循环。
递归函数在解决许多数学问题上起了至关重要的作用,比如计算一个数的阶乘、生成斐波那契数列,等等。
数的阶乘
下面的实例使用递归函数计算一个给定的数的阶乘:
#include <stdio.h>
int factorial(unsigned int i){
if(i <= 1){
return 1;
}
return i * factorial(i - 1);
}
int main() {
int i = 15;
printf("Factorial of %d is %d\n", i, factorial(i));
return 0;
}
当上面的代码被编译和执行时,它会产生下列结果:
Factorial of 15 is 2004310016
斐波那契数列
下面的实例使用递归函数生成一个给定的数的斐波那契数列:
#include <stdio.h>
int fibonaci(int i){
if(i == 0){
return 0;
}
if(i == 1){
return 1;
}
return fibonaci(i-1) + fibonaci(i-2);
}
int main(){
int i;
for (i = 0; i < 10; i++){
printf("%d\t%n", fibonaci(i));
}
return 0;
}
当上面的代码被编译和执行时,它会产生下列结果:
0 1 1 2 3 5 8 13 21 34