C 语言函数:入门指南
C 语言中的函数声明和定义
您可以通过以下方式创建并调用函数:
一个函数包括两个部分:
声明:函数名称、返回类型和参数(如果有)
定义:函数体(要执行的代码)
为了优化代码,建议将函数的声明和定义分开。
您经常会看到 C 程序在 main() 之前有函数声明,在 main() 之后有函数定义。这将使代码更整齐,更易于阅读:
另一个例子:
如果我们使用上一章关于函数参数和返回值的示例:
相反,最好写成这样:
这是一种很好的实践,因为它可以使代码更易于阅读和理解。它还允许您在其他文件或模块中使用函数声明,而无需包含整个函数定义。
C 语言中的递归
递归是指使函数调用自身的技巧。这种技术提供了一种将复杂问题分解为更易于解决的简单问题的途径。
递归可能有点难懂。弄清楚它如何工作的最佳方法是进行试验。
递归示例
将两个数字相加很容易,但将一系列数字相加就比较复杂了。在以下示例中,递归用于通过将问题分解为将两个数字相加的简单任务来将一系列数字相加:
示例解释
当调用 sum() 函数时,它将参数 k 添加到所有小于 k 的数字的和中并返回结果。当 k 变成 0 时,函数只返回 0。程序运行时,会遵循以下步骤:
10 + sum(9)
10 + (9 + sum(8))
10 + (9 + (8 + sum(7)))
...
10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + sum(0)
10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + 0
由于函数在 k 为 0 时不调用自身,因此程序在此停止并返回结果。
开发人员应该非常小心地使用递归,因为它很容易写出永远不会终止的函数,或者会使用过多的内存或处理器资源的函数。然而,当正确编写时,递归可以成为一种非常高效和数学上优雅的编程方法。
C 语言中的数学函数
C 语言中还提供了一系列数学函数,允许您对数字进行数学运算。
要使用它们,您必须在程序中包含 math.h 头文件:
平方根
要找到某个数字的平方根,请使用 sqrt() 函数:
四舍五入
ceil() 函数将数字向上舍入到最接近的整数,floor() 函数将数字向下舍入到最接近的整数,并返回结果:
幂次
pow() 函数返回 x 的 y 次方 (xy) 的值:
其他数学函数
以下表格列出了 <math.h> 库中其他常用的数学函数:
最后
为了方便其他设备和平台的小伙伴观看往期文章:
微信公众号搜索:Let us Coding
,关注后即可获取最新文章推送
看完如果觉得有帮助,欢迎 点赞、收藏、关注
版权声明: 本文为 InfoQ 作者【小万哥】的原创文章。
原文链接:【http://xie.infoq.cn/article/88051019254f1bded9116d013】。文章转载请联系作者。
评论