前提・実現したいこと
コマンドライン入力に20と入力した場合に 標準出力に83621143489848422977と出力されることを求めています。
「コマンドライン入力」に正の整数値 n を入力すると,動的な配列を生成し,n 桁以下のフィボナッチ数で最大のもの計算して画面上(標準出力)に表示するプログラムを作成。
発生している問題・エラーメッセージ
実行時間が3秒を超えました。
該当のソースコード
#include <stdio.h> #include <stdlib.h> int main(int argc, char *argv[]) { char *a, *b, *c; int i, n, na, nb, nc, r; if (argc != 2) { printf("usage: %s number_of_digits\n", argv[0]); return 1; } n = atoi(argv[1]); if(n < 1) { puts("number of digits should be greater than 1"); return 1; } 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 ### 試したこと 以下、プログラムを入れてみたが、エラーメッセージが出た。 + if (argc != 2 || (n = atoi(argv[1])) < 1) return 1; 以下を追記 nc = nb + 1;