c语言的cps实现求fibonacci数列示例

Orianna ·
更新时间:2024-09-20
· 568 次阅读

CPS:http://en.wikipedia.org/wiki/Continuation-passing_style
示例代码使用迭代 + 尾递归。

代码如下:
#include <stdio.h>

typedef void (*END_OF_END)(unsigned long);
void fibonacci(int, unsigned long, unsigned long, void(*)(unsigned long));

void
notify(unsigned long res) {
  printf("Ultimate result: %lu\n" res);
  exit(0);
}

/* Note: Fibonacci number might overflow! */
void
fibonacci(int n, unsigned long v1, unsigned long v2, void(*notify)(unsigned long)) {
  if (n <= 0) notify(v2);
  fibonacci(n - 1, v2, v1 + v2, notify);
}

int
main(void) {
  fibonacci(100 - 2, 1, 1, notify);
  return 0;
}

您可能感兴趣的文章:c++输出斐波那契数列示例分享C语言使用普通循环方法和递归求斐波那契序列示例代码C++求斐波那契数的实例代码C++输出斐波那契数列的两种实现方法c#斐波那契数列(Fibonacci)(递归,非递归)实现代码C语言求Fibonacci斐波那契数列通项问题的解法总结



cps 示例 C语言

需要 登录 后方可回复, 如果你还没有账号请 注册新账号