【C语言】递归函数&变量的作用域

变量的作用域

全局变量:在整个程序内可以识别,且唯一。

局部变量:仅在当前函数内有效,比如main函数、用户自定义函数。

递归函数

指的是一类函数,函数调用自身,包括递推和回归。使用递归的方式,可使得代码更加简洁,问题分析时只需要分析递归结束条件,以及每一步和下一步之间的关系。

cpp 复制代码
#include <stdio.h>
#include <math.h>
/*	功能:函数中变量的作用域&递归函数 (求n的阶乘) 
	时间:2024年10月 
	地点:贤者楼129 
	作者:LChen
*/

/* 变量作用域:局部变量:只在函数体内作用
				全局变量:整个程序内部有效
	递归函数:函数调用自身,递推&回归
				更加简洁 
*/ 

long long Fact1(int n);			// 非递归函数求解 
long long Fact2(int n);			// 递归函数求解 

int count=1;						// 全局变量,任意地方可以调用 
 
int main() {
	
	int m;
	
	scanf("%d",&m);
	
	if(m<0) {
		printf("输入错误!\n");
		return 0; 
	}
	
	int fact1=Fact1(m);				// 函数调用,传递实参 
	int fact2=Fact2(m);

	printf ("n!循环:%lld\n",fact1);
	printf ("n!递归:%lld\n",fact2);

	return 0;
}

long long Fact1(int n) {			// 非递归,循环实现 

	// 函数内部调用全局变量 
	printf("count=%d\n",++count);
	
//	// 调用局部变量main()中的变量m,-->编译错误
//	printf("m=%d\n",m);			
	
	int i;
	long long f=1;
	for(i=1;i<=n;i++)
		f*=i;
	return f;
}

long long Fact2(int n) {			// 递归,复杂问题转化为同类型方法 
	
	if(!n) 							// 递归终止条件 
		return 1;
	return n*Fact2(n-1);			// 等待调用结果后返回最终值 
}
相关推荐
烤麻辣烫8 分钟前
黑马程序员苍穹外卖(新手)DAY12
java·开发语言·学习·spring·intellij-idea
MM_MS14 分钟前
C# 线程与并发编程完全指南:从基础到高级带详细注释版(一篇读懂)
开发语言·机器学习·计算机视觉·c#·简单工厂模式·visual studio
t***316515 分钟前
QT开发:事件循环与处理机制的概念和流程概括性总结
开发语言·qt
龙泉寺天下行走25 分钟前
[PowerShell 入门教程] 第9.5天(间章):PowerShell 常见 Cmdlet 速查手册
开发语言·php
muxin-始终如一31 分钟前
Semaphore 使用及原理详解
java·开发语言·python
名扬9111 小时前
webrtc编译问题-ubuntu
开发语言·python
白云千载尽1 小时前
Python 初学者 / 中级开发者常踩坑的 10 个坑 —— 要用好几年才能彻底搞清楚的
开发语言·python
Evand J1 小时前
【MATLAB雷达滤波代码】二维,单雷达跟踪与滤波。EKF融合雷达的距离、角度+目标IMU数据。附代码下载链接
开发语言·matlab·雷达·ekf·雷达跟踪·角度观测
weixin_462446231 小时前
【原创实现】Python 实现 PDF 批量压缩工具(支持逐个确认 / 批量处理 / 多级压缩)
开发语言·python·pdf
沐知全栈开发1 小时前
Bootstrap 轮播教程与最佳实践
开发语言