C语言函数复习全解析:参数、无参、嵌套与递归

ops/2024/10/20 20:57:48/

C语言复习

函数篇

文中包括调用有参函数和无参函数、函数的嵌套和递归。首先,通过一道
例题介绍了有参函数的概念和用法,即定义一个函数,接受特定参数并返回结果。接着,讲解了无参函数,即执行函数时不需要返回数值,只执行特定操作。然后,介绍了函数的嵌套,即在一个函数内部调用另一个函数。最后,讲解了函数的递归,即函数调用自身的过程,通过递归函数可以解决一些复杂问题。通过实例详细解释了函数的定义、调用和解释方
法,以及函数在编程中的实际应用。

有参函数的定义与应用
1.有参函数是要求输入参数的函数,通过输入参数来
执行特定操作。
2.通过输入四个数字的例子,展示了如何编写一个程
序来比较和输出前两个数中最大的数,后两个数中最
大的数以及四个数中最大的数
3.使用了三个if else语句来比较不同数组中的元素
找到最大值。

无参函数的调用

无参函数类似,需要在调用
前声明函数名,在调用后解释函数的作用。
无参函数的调用
1.无参函数不返回任何值,主要用于执行特定操作而
不返回结果。
2.通过输出特定文本的例子,展示了如何调用无参函
数来实现特定功能。
3.无参函数的调用方法与有

函数的嵌套和函数的递归
函数的嵌套调用
1.函数可以嵌套调用其他函数,这种调用方式称为函
数的嵌套调用。
2.通过输入四个整数并找出最大值的例子,展示了如
何使用嵌套函数来解决问题
3.嵌套函数调用的方法是在外层函数中声明要调用的
内层函数,并在内层函数中执行相应

已经给出了函数篇的大纲和部分内容的描述。接下来,将为提供更详细的解释和一些代码示例,以帮助更好地理解和复习C语言中的函数。

有参函数的定义与应用

有参函数是带有参数的函数,这些参数在函数调用时传递,并用于函数内部的计算或操作。

示例:比较四个数字并找出最大值。

c

#include <stdio.h>  // 比较两个数,返回最大值  
int max(int a, int b) {  return (a > b) ? a : b;  
}  // 比较四个数,返回最大值  
int max_of_four(int a, int b, int c, int d) {  int max1 = max(a, b);  int max2 = max(c, d);  return max(max1, max2);  
}  int main() {  int a = 1, b = 2, c = 3, d = 4;  printf("The maximum value among %d, %d, %d, and %d is %d\n", a, b, c, d, max_of_four(a, b, c, d));  return 0;  
}

无参函数的调用

无 参函数不接受任何参数,通常用于执行某些特定的操作或任务。

示例:输出一条欢迎消息。

#include <stdio.h>  // 无参函数,输出欢迎消息  
void print_welcome() {  printf("Welcome to the program!\n");  
}  int main() {  print_welcome();  // 调用无参函数  return 0;  
}

函数的嵌套调用

函数的嵌套调用指的是在一个函数中调用另一个函数。

示例:使用嵌套函数调用来找出四个数中的最大值(与前面的示例相似,但结构不同)。

 

c复制代码

#include <stdio.h>  int max(int a, int b) {  return (a > b) ? a : b;  
}  int max_of_two_pairs(int a, int b, int c, int d) {  int max_ab = max(a, b);  int max_cd = max(c, d);  return max(max_ab, max_cd);  // 嵌套调用max函数  
}  int main() {  int a = 1, b = 5, c = 3, d = 7;  printf("The maximum value is %d\n", max_of_two_pairs(a, b, c, d));  return 0;  
}

递归是函数自己调用自己的过程。递归函数常用于解决可以分解为更小相似问题的问题。

示例:计算阶乘。

 
#include <stdio.h>  // 递归函数计算阶乘  
long long factorial(int n) {  if (n == 0 || n == 1) {  return 1;  } else {  return n * factorial(n - 1);  // 递归调用自己  }  
}  int main() {  int number = 5;  // 可以更改此值来计算不同数的阶乘  printf("Factorial of %d is %lld\n", number, factorial(number));  return 0;  
}

咱们下期见


http://www.ppmy.cn/ops/45295.html

相关文章

2024最新彩虹聚合DNS管理系统源码v1.3 全开源

2024最新彩虹聚合DNS管理系统源码v1.3 全开源 聚合DNS管理系统可以实现在一个网站内管理多个平台的域名解析&#xff0c;目前已支持的域名平台有&#xff1a;阿里云、腾讯云、华为云、西部数码、DNSLA、CloudFlare。 本系统支持多用户&#xff0c;每个用户可分配不同的域名解…

【学习笔记】第二章 Scala入门——Scala安装和运行

一、Scala的安装方法 要使用Scala&#xff0c;首先需要保证已经安装好了Java 8。对于Linux操作系统&#xff0c;Java 8已经默认安装了&#xff0c;而使用Windows操作系统的用户&#xff0c;则需要在Java官网下载安装包进行安装。请在CMD、PowerShell或终端中运行“java -versio…

Docker部署SpringBoot项目(jar包+Mysql)

部署Java项目 项目准备准备Java项目镜像准备配置网络 部署项目细节展示 项目准备 准备Java项目 hmall项目是一个maven聚合项目&#xff0c;使用IDEA打开hmall项目&#xff0c;查看项目结构如图&#xff1a; 我们要部署的就是其中的hm-service&#xff0c;其中的配置文件采用…

【MySQL精通之路】SQL优化(1)-查询优化(13)-条件过滤

在联接处理中&#xff0c;前缀行是从联接查询中的一个表传递到下一个表的那些行。 通常&#xff0c;优化器会尝试在联接查询的早期放置前缀计数较低的表&#xff0c;以防止行组合的数量快速增加。 在某种程度上&#xff0c;优化器可以使用从一个表中选择并传递到下一个表的行…

kali基本扫描工具(自带)

免责声明:本文仅做技术交流与学习...请勿非法破坏... 详细用法: 命令 -h/百度/翻译 fping 用法 hostlist 文件里面为ip fping -a -q -f hostlist -a 只看存活的 fping -g 202.100.1.1 202.100.1.255 -a -q > Ahost 输出到Ahost文件上 nping nping -c 1 201.100.2.155-244 …

openLayers加载wms图层并定位到该图层

openLayers定位到wms图层 我们的wms是加载geoserver发布的服务&#xff0c;wms加载的图层是没法通过layer.getSource().getExtent()来获取到extents&#xff08;边界&#xff09;的&#xff1b;实现思路是通过postgis的函数(st_extent(geom))来获取extents; 返回前端后格式化一…

最新文章合集

GitHub宝藏项目&#xff1a;每天一个&#xff0c;让你的技术库增值不停&#xff01; STORM、SuperMemory、Awesome Chinese LLM、AI写作助手、资料搜集、文章生成、视角问题引导、模拟对话策略、内容导入、浏览器插件、资源库、开源微调模型 开发者必看&#xff1a;Linux终端…

leetcode 684.冗余连接

思路&#xff1a;并查集 这里的图比较像一种特殊的数据结构&#xff0c;其实也是图论的一种东西&#xff0c;就是基环树&#xff0c;但是这里并不是有向图&#xff0c;而是无向图&#xff0c;所以并不能用那种剪枝操作然后找基环。 看到连通量&#xff0c;我们应该能想到两种…