当前位置: 首页 > 知识库问答 >
问题:

在C语言中,如何递归调用以void函数作为参数的函数?

司空学智
2023-03-14

我是一个C的初学者,我想使用一个具有空函数的空函数作为传递的参数,然后我想用递归的方式调用它。例如空inorder(结构节点*根,空(*f)(结构节点*i))但是很明显,我不能使用它,因为参数没有返回类型。有人对如何递归调用它有什么建议吗?谢谢!

共有1个答案

丌官积厚
2023-03-14

注释中显示的代码,void inOrder(root)-

  • 无效不应该出现。当调用一个函数时,我们只在括号中写它的名字和参数。我们不声明它的类型。
  • 表达式inorder(root-
inOrder(root->leftChild, f)

还要注意的是,您不是递归调用ff不直接或间接调用finoorder可能会调用自身,因此它会递归,但它只是简单地调用f,而不是递归地调用。

 类似资料:
  • 我是新的编码和需要作出曼德尔布罗特函数。对于那些不知道的人来说,Mandelbrot集合是一组复数。从本质上讲,你可以从一个复数开始,然后把它平方,然后把它加到原来的复数中。例如,如果我使用数字1,集合将是0、1、2、5、26。。。我从0,1,(1^2)1=2,(2^2)1=5,(5^2)1=26得到这个值。现在,我的递归函数应该使用两个输入来求这个集合的和:一个数字n,它是我们进入集合的距离。例

  • 主要内容:斐波那契数列,数字阶乘,多个函数组成递归很对编程语言都支持递归函数,Go语言也不例外,所谓递归函数指的是在函数内部调用函数自身的函数,从数学解题思路来说,递归就是把一个大问题拆分成多个小问题,再各个击破,在实际开发过程中,递归函数可以解决许多数学问题,如计算给定数字阶乘、产生斐波系列等。 构成递归需要具备以下条件: 一个问题可以被拆分成多个子问题; 拆分前的原问题与拆分后的子问题除了数据规模不同,但处理问题的思路是一样的; 不能无限制的

  • 递归,就是在运行的过程中调用自己。 语法格式如下: func recursion() { recursion() /* 函数调用自身 */ } func main() { recursion() } Go 语言支持递归。但我们在使用递归时,开发者需要设置退出条件,否则递归将陷入无限循环中。 递归函数对于解决数学上的问题是非常有用的,就像计算阶乘,生成斐波那契数列等。 阶乘 以下实

  • 在 Go 语言开篇中我们已经知道,Go 语言与 C 语言之间有着千丝万缕的关系,甚至被称之为 21 世纪的C语言。 所以在 Go 与 C 语言互操作方面,Go 更是提供了强大的支持。尤其是在 Go 中使用 C,你甚至可以直接在 Go 源文件中编写 C 代码,这是其他语言所无法望其项背的。 格式: 在 import "C" 之前通过单行注释或者通过多行注释编写C语言代码 在 import "C" 之

  • 主要内容:递归的进入,递归的退出,递归的条件,更多关于递归函数的内容一个函数在它的函数体内调用它自身称为 递归调用,这种函数称为 递归函数。执行递归函数将反复调用其自身,每调用一次就进入新的一层,当最内层的函数执行完毕后,再一层一层地由里到外退出。 递归函数不是C语言的专利, Java、 C#、 JavaScript、 PHP 等其他编程语言也都支持递归函数。 下面我们通过一个求阶乘的例子,看看递归函数到底是如何运作的。阶乘 n! 的计算公式如下: 根据公式编写如

  • 作为 C 语言程序的入口 mian 函数很多时候会在启动的时候从外界传入一些参数到程序内部。 1. main 函数的参数 其实从函数角度的讲, mian 函数和其它函数没有什么特别之处。只不过这个函数是又操作系统直接引导的,在大多数的情况下是程序的入口。因此而显得特殊。 之前我们介绍的程序中都是没有参数的 mian 函数,这里我们看一下一般情况下 mian 函数的参数情况。 int main(in