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

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

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;  
}

咱们下期见

相关文章:

  • 【Docker】2、配置SSL证书远程访问Docker
  • Golang面试手册
  • springboot项目使用validated参数校验框架
  • 为什么国际顶级黑客大都没学过计算机专业,而是自学成才?
  • Docker安装nginx详细教程
  • React 使用JSX或者TSX渲染页面
  • LLAMA3==shenzhi-wang/Llama3-8B-Chinese-Chat。windows安装不使用ollama
  • day21二叉树part07|530.二叉搜索树的最小绝对差 501.二叉搜索树中的众数 236. 二叉树的最近公共祖先
  • 【网络运维的重要性】
  • 学习C++编程入门:时间、方法及经验分享
  • Unix环境高级编程--7-进程环境--7.1-7.2main函数-7.3进程退出
  • 人工智能初识
  • DOS学习-目录与文件应用操作经典案例-del
  • 2024年3月电子学会青少年软件编程 中小学生Python编程等级考试一级真题解析(选择题)
  • Flutter 中的 NestedScrollViewViewport 小部件:全面指南
  • AWS实战 - 利用IAM对S3做访问控制
  • bootstrap创建登录注册页面
  • canvas绘制圆角头像
  • echarts的各种常用效果展示
  • EOS是什么
  • Eureka 2.0 开源流产,真的对你影响很大吗?
  • exif信息对照
  • Facebook AccountKit 接入的坑点
  • Nacos系列:Nacos的Java SDK使用
  • Vue.js-Day01
  • Vue--数据传输
  • 从零开始在ubuntu上搭建node开发环境
  • 大型网站性能监测、分析与优化常见问题QA
  • 每个JavaScript开发人员应阅读的书【1】 - JavaScript: The Good Parts
  • 前端学习笔记之观察者模式
  • 使用 Xcode 的 Target 区分开发和生产环境
  • 算法之不定期更新(一)(2018-04-12)
  • 王永庆:技术创新改变教育未来
  • 浅谈sql中的in与not in,exists与not exists的区别
  • ​Spring Boot 分片上传文件
  • #Linux(Source Insight安装及工程建立)
  • (2024最新)CentOS 7上在线安装MySQL 5.7|喂饭级教程
  • (Qt) 默认QtWidget应用包含什么?
  • (ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY)讲解
  • (SpringBoot)第七章:SpringBoot日志文件
  • (ZT)出版业改革:该死的死,该生的生
  • (定时器/计数器)中断系统(详解与使用)
  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • (转)微软牛津计划介绍——屌爆了的自然数据处理解决方案(人脸/语音识别,计算机视觉与语言理解)...
  • (轉貼) UML中文FAQ (OO) (UML)
  • * CIL library *(* CIL module *) : error LNK2005: _DllMain@12 already defined in mfcs120u.lib(dllmodu
  • ***监测系统的构建(chkrootkit )
  • **PHP分步表单提交思路(分页表单提交)
  • .netcore如何运行环境安装到Linux服务器
  • ??eclipse的安装配置问题!??
  • @Autowired多个相同类型bean装配问题
  • @Controller和@RestController的区别?
  • @Validated和@Valid校验参数区别
  • []T 还是 []*T, 这是一个问题
  • [16/N]论得趣