在 C 中递归计算斐波那契数列

标签 c fibonacci

我正在尝试通过编写一个简单的程序来学习 C 来输出斐波那契数列。它不起作用。

斐波那契.h

unsigned int fibonacci_recursive(unsigned int n);

斐波那契.c

#include <stdio.h>
#include "fibonacci.h"

main() {
    unsigned int i;
    for (i = 0; i < 10; i++) {
        printf("%d\t%n", fibonacci_recursive(i));
    }
    getchar();
}

fibonacci_recursive.c

unsigned int fib_rec(unsigned int n);

main(unsigned int n) {
     return fib_rec(n);
}

unsigned int fib_rec(unsigned int n) {
    if (n == 0) {
        return 0;
     } 
     if (n == 1) {
           return 1;
     }
     return fib_rec(n - 1) + fib_rec(n - 2);
}

这是我尝试构建项目时 VS 2010 给我的错误消息:

1>ClCompile:
1>  fibonacci_recursive.c
1>fibonacci_recursive.obj : error LNK2005: _main already defined in fibonacci.obj
1>fibonacci.obj : error LNK2019: unresolved external symbol _fibonacci_recursive referenced in function _main
1>c:\users\odp\documents\visual studio 2010\Projects\Fibonacci\Debug\Fibonacci.exe : fatal error LNK1120: 1 unresolved externals
1>
1>Build FAILED.
1>

我在这里做错了什么?感谢您帮助刚接触 C 语言的人。

最佳答案

你的方法看起来很奇怪,你应该:

  • 一个包含主要方法的主文件(例如 main.c),其中包括 fibonacci.h
  • fibonacci.h 原型(prototype)为 unsigned int fibonacci_recursive(unsigned int n);
  • 一个包含方法实现的fibonacci.c,它也应该包含fibonacci.h

实际上你也定义了两次 main 函数..

ma​​in.c

#include <stdio.h>
#include "fibonacci.h"

main()
{
    unsigned int i;
    for (i = 0; i < 10; i++)
    {
        printf("%d\t%n", fibonacci_recursive(i));
    }
    getchar();
}

斐波那契.h

unsigned int fibonacci_recursive(unsigned int n);

斐波那契.c

#include "fibonacci.h"
unsigned int fibonacci_recursive(unsigned int n)
{
    if (n == 0) 
    {
        return 0;
     } 
     if (n == 1) {
           return 1;
     }
     return fibonacci_recursive(n - 1) + fibonacci_recursive(n - 2);
}

关于在 C 中递归计算斐波那契数列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2170276/

相关文章:

c - 从 ANSI C 代码获取控制流图

c - 用于矩阵和双指针

Haskell Fibonacci 似乎很慢

javascript - 使用数组作为输入参数实现斐波那契

python - 如何从 range() 函数中获取最后一个数字?

c - 如何将浮点输入转换为整数并保持最大精度?

c - 我的 C 编程很生疏,并且遇到了一些问题

f# - 在F#中生成斐波那契数列

Common Lisp 中的递归、推值和斐波那契数列

c - 使用 Visual Studio Express C++ 进行 C 编程的设置和配置?