r - 使用 Rcpp 的斐波那契数列的意外结果

标签 r rcpp

我刚开始使用 Rcpp很抱歉,如果我错过了一个简单的步骤或类似的东西......我已经从 ?sourceCpp 尝试过这个

library(Rcpp)
sourceCpp(code='
  #include <Rcpp.h>

  // [[Rcpp::export]]
  int fibonacci(const int x) {
    if (x == 0) return(0);
    if (x == 1) return(1);
    return (fibonacci(x - 1)) + fibonacci(x - 2);
  }'
)

高达 fibonacci(46)一切都很好,但后来我得到:
> fibonacci(47)
[1] -1323752223
> fibonacci(48)
[1] 512559680
> fibonacci(49)
[1] -811192543
> fibonacci(50)
[1] -298632863

根据这个page以上应该是:
47 : 2971215073
48 : 4807526976
49 : 7778742049
50 : 12586269025

你得到同样的结果吗?

最佳答案

您超出了 maximum limit对于有符号整数(从技术上讲,这将是 long int 我猜)。使用 double反而...

library(Rcpp)
sourceCpp(code='
  #include <Rcpp.h>

  // [[Rcpp::export]]
  double fibonacci(const double x) {
    if (x == 0) return(0);
    if (x == 1) return(1);
    return (fibonacci(x - 1)) + fibonacci(x - 2);
  }'
)

fibonacci(47)
#[1] 2971215073

关于r - 使用 Rcpp 的斐波那契数列的意外结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18877472/

相关文章:

r - 在 R 中的数据帧中对低发生级别进行分组

c++ - 获取R数据帧的内存地址

r - 通过引用传递 data.frame 并使用 rcpp 更新它

r - 从同一包中的 R 代码调用 Rcpp c++​​ 函数

r - 访问插入符号中 rfe 生成的所有模型

r - 使用ggrepel覆盖水平定位

r - geom_map "map_id"函数如何工作?

r - 获取与一系列向量一致的矩阵行,而不使用 apply

r - mac 中 Rcpp 包中的 dyn.load 错误

r - 并行化采用外部指针的函数 (XPtr)