ボールドテキスト「正の整数値 n を入力すると,動的な配列を生成し,n 桁以下のフィボナッチ数で最大のもの計算して表示するプログラムを作成してください」という課題で、ここまでは作れたのですがこれ以降がわかりません。
#include <stdio.h> #include <stdlib.h> int main(void) { char *a, *b, *c; int i, n, na, nb, nc, r; scanf("%d", &n); a = calloc(n+1, sizeof(char)); b = calloc(n+1, sizeof(char)); c = calloc(n+1, sizeof(char)); if ((a == NULL) || (b == NULL) || (c == NULL)) { printf("cannot allocate memory.\n"); exit(1); } a[0] = 0; b[0] = 1; na = nb = 1; for (; nb<=n;){ r = 0; for (i=0; i!=nb; i++) { r = a[i] + b[i] + r; c[i] = r % 10; r = r / 10; } if (r == 1) { c[i] = 1; nc = nb + 1; } else { nc = nb; } for (i=0; i!=nb; i++) a[i] = b[i]; for (i=0; i!=nc; i++) b[i] = c[i]; na = nb; nb = nc; } for (i=na-1; i>=0; i--) printf("%d", a[i]); printf("\n"); free(a); free(b); free(c); return 0; }
ソースコードがC#ではありません。見る限りでは恐らくC言語だと思われるので、そちらに質問のタグを変更してください。
回答1件
あなたの回答
tips
プレビュー