程序调用自身的编程技巧,一个过程或函数在其定义中直接或者间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需要少量的程序就可以描述出解题过程所需要当多次重复计算,大大减少了程序的代码量。
ifndef是指如果没有定义过 ,后面用define定义
#endif就是结束了,这段包含就结束了。
一段史上最简单的递归函数,但是会出现👇栈溢出的问题。
我们需要给内存分为几个区域,在C语言中我们划分的区域分为,栈区、堆区、静态区
局部变量在栈区,函数的形参也放在栈区。堆区里面放动态开辟的内存,malloc这些函数开辟的空间。静态区的全局变量,比如static修饰的变量。
练习一、接收一个整型数(无符号),按照顺序打印它的每一位。
接下来我们需要求字符串长度,简单的代码如下:
如果我们需要自己创造一个函数去求出字符串长度。
重点是🀄️:arr传参传过去的不是整个数组,而是首元素的地址。
如果说题目要求🈯️:不能创建临时变量,那么我们该如何自定义函数求字符串长度。