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

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

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

  2021-03-19 我要评论
想了解c语言的cps实现求fibonacci数列示例的相关内容吗,在本文为您仔细讲解fibonacci数列的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:c语言,cps,fibonacci数列,下面大家一起来学习吧。

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


Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们