1. 函数定义
语法:
类型标识符 函数名(形式参数)
{
函数体代码
}
(1)类型标识符 --- 数据类型(函数要带出的结果的类型)
注:数组类型不能做函数返回结果的类型,如果函数不需要带出什么结果,此时返回结果的类型说明符为void,如果返回结果的类型与类型说明符不一致,以类型说明符为准(类型说明符不写,默认为int)。
(2)函数名 --- 标识符,符合标识符命名规则
(3)形式参数 --- 表示改函数需要用到的数据
注:每一个形参变量都得指定类型,实参和形参需要类型匹配,参数个数相同,顺序一一对应,如果不需要接收实际参数,形参一般设计为void
(4)函数体代码 --- 实现函数功能的代码。
写法:
数据类型 形参变量名1,数据类型 形参变量2...
int a,int b
int a,b // 不能这样写
2. 函数调用
函数调用的本质:实际上是利用栈的结构,先进后出,保证了函数可以层层嵌套调用。
调用者和被调用者:main函数时整个程序的入口,只能是调用者
注:函数不支持嵌套定义,但是可以嵌套调用
函数名是函数的入口地址。
3. 递归
可以实现循环的功能,是一种特殊的循环。
直接递归:自己调用自己
间接调用:调用其他函数,其他函数调用了自己,这样又实现了调用自己。
代码实现思路:
(1)递推关系 --- 从问题n到问题n - 1;
(2)递推结束的条件
eg:前 n 项的累加求和
sum(n)=> sum(n-1)+ n //递推关系
n = 1; // 结束条件
#include<stdio.h>
int sum(int n)
{
if(n==1) // 递推结束条件
{
return 1;
}else
{
return sum(n-1)+n; // 递推关系
}
}
int main(void)
{
int n;
printf("Input a num:");
scanf("%d",&n);
int ret = sum(n);
printf("%d\n",ret);
return 0;
}
代码运行结果:
4. 数组作为函数参数
(1)数组元素作为函数参数--- a[0]
(2)数组本身作为函数参数--- a
形参--- 写成数组形式,还需要数组长度
实参--- 数组名,数组长度
printfArray(int a[],int len) // 形参
printArray(a,len); //调用
eg:打印数组元素
#include<stdio.h>
void printArray(int a[],int len) // 定义形参
{
int i = 0;
for(i = 0;i < len;++i)
{
printf("a[%d] = %d\n",i,a[i]);
}
}
int main(void)
{
int a[] = {1,2,3,4,5,6,7,8,9};
int len = sizeof(a)/sizeof(a[0]);
printArray(a,len); // 调用时传入实参
return 0;
}