0

现在我正在寻找一个可以执行基本线性代数的程序,其中我有 2 个常数:A 和 B,我可以简单地输入它们的系数并在其上添加其他值。

例子:

假设我想找到斐波那契数列的项

A
B

我想拿 A + B 并将其附加到文件中。

A
B
A+B

现在我想添加第二个和第三个学期

A
B
A + B
A + 2B

等等。

我有一个程序可以很好地对所有数值执行此操作,但是,我希望看到它以代数方式上升,而不使用 binets 公式。

我唯一的猜测是将 A 和 B 的系数存储到 2 个单独的文件中,以便计算它们然后将它们打印出来,但是,如果线性代数在 C 中可用,它会容易得多。

编辑:没关系,我忘了这是一个适合计算机书呆子的地方,而不是数学书呆子

4

1 回答 1

1

作为传统的命令式语言,C 没有对代数表达式的内置支持。要计算斐波那契数列的系数,您可以编写如下程序:

#include <stdio.h>

int main() {
    int i;
    int coeff_a_1 = 1;
    int coeff_b_1 = 0;
    int coeff_a_0 = 0;
    int coeff_b_0 = 1;

    printf("A\n");
    printf("B\n");

    for (i = 0; i < 15; i++) {
        int coeff_a = coeff_a_0 + coeff_a_1;
        int coeff_b = coeff_b_0 + coeff_b_1;

        printf("%dA + %dB\n", coeff_a, coeff_b);

        coeff_a_1 = coeff_a_0;
        coeff_b_1 = coeff_b_0;
        coeff_a_0 = coeff_a;
        coeff_b_0 = coeff_b;
    }

    return 0;
}

这将打印:

A
B
1A + 1B
1A + 2B
2A + 3B
3A + 5B
5A + 8B
8A + 13B
13A + 21B
21A + 34B
34A + 55B
55A + 89B
89A + 144B
144A + 233B
233A + 377B
377A + 610B
610A + 987B

对于更复杂的问题,我建议使用提供 C 绑定的计算机代数系统。

于 2015-03-16T11:03:24.237 回答