当前位置: 首页 > article >正文

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

变量的作用域
全局变量:在整个程序内可以识别,且唯一。
局部变量:仅在当前函数内有效,比如main函数、用户自定义函数。

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

#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);			// 等待调用结果后返回最终值 
}

在这里插入图片描述


http://www.kler.cn/news/354778.html

相关文章:

  • Elasticsearch(二)集成Spring Boot 基本的API操作
  • oracle实例宕机,虚拟机磁盘精简配置模式,磁盘无法扩展
  • C++ 内存管理 对比C语言动态内存管理;operator new和delete
  • 洛谷 P1803:凌乱的yyy / 线段覆盖 ← 贪心算法
  • (C/C++)文件
  • 鼠标市场洞察:数据分析揭示消费趋势!
  • 如何解决MQ的重复消费问题?Kafka、ActiveMQ、RabbitMQ有什么区别?
  • 低功耗 ARMxy工业计算机:工业场景的绿色新选择
  • Linux 简述基于 TCP 连接状态分析网络排障
  • 【C语言】函数的声明与定义
  • Windows 和 Ubuntu通讯的网络设置
  • 无技能,学历不高?想要找一份高薪工作,通信网优肯定适合你
  • 影楼即将倒闭!!!!stable diffusion comfyui制作:AI人像摄影专业工作流
  • python string中提取中文字符处理之后插入回原string
  • 【python爬虫基础】年轻人的第一个爬虫程序
  • C++简单多状态dp:按摩师、打家劫舍II、删除并获得点数、粉刷房子
  • 2024全新UI网址发布页源码带黑夜模式
  • WebSocket介绍和入门案例
  • xavier 在tensorflow pytorch中的应用,正太分布和均匀分布的计算公式不一样
  • 串的模式匹配算法_BF算法