質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

2回答

3160閲覧

フィボナッチ数を計算

退会済みユーザー

退会済みユーザー

総合スコア0

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2020/01/24 14:57

編集2020/02/04 04:39

フィボナッチ数を計算する関数

long int f(int n)

を再帰呼出しで関数定義した場合に、与えられた非負整数 n を引数とする呼出し f(n) に対して関数 f が呼び出される回数を数え、計算されたフィボナッチ数とともにその回数を標準出力に書き出すプログラムを作りたい。

プログラムの仕様はつぎの通りです。

非負整数 n はコマンドライン引数に与えられる。
出力は、つぎの形式として1行として書き出すこと。
u [c times]
u は n 番目のフィボナッチ数の値、 c はその計算での関数呼出しの回数
u と [ の間、c と times の間には、それぞれ空白1文字をおくこと。

■実行例
コマンドライン入力

0

標準出力

0 [1 times]

コマンドライン入力

1

標準出力

1 [1 times]

コマンドライン入力

10

標準出力

55 [177 times]

C

1#include <stdio.h> 2#include <stdlib.h> 3 4long int f(int n); 5int main(int argc, char *argv[]){ 6 ・・・ 7 return 0; 8} 9long int f(int n){ 10 if( n<=1 ) return n; 11 return f(n-1)+f(n-2); 12}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

y_waiwai

2020/01/24 15:00

自分なりにコードを書きましょう
guest

回答2

0

ベストアンサー

c

1#include <stdio.h> 2#include <stdlib.h> 3 4long int f(int n); 5 6int count = 0; 7 8int main(int argc, char *argv[]) { 9 count = 0; 10 int n = atoi(argv[1]); 11 12 int res = f(n); 13 printf("%d [%d times]\n", res, count); 14 return 0; 15} 16 17long int f(int n) { 18 count++; 19 if (n <= 1) { 20 return n; 21 } 22 return f(n - 1) + f(n - 2); 23}

実行例
イメージ説明

投稿2020/01/25 01:13

katoy

総合スコア22324

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/25 01:43

ご回答有難うございます! 流石上位の方...!! 大変助かりました☻
katoy

2020/01/25 01:59

次の点の改良もかんがえてみてください。 1. グローバル変数 count を使わないようにする。 2. 計算結果が int の範囲を超えてしまう場合に対処する。
guest

0

プログラムの仕様ではnの上限が定められておらず、intの最大値を超えた場合に関数long int f(int n)で計算することはできません。多倍長整数を使って書き直してください。

投稿2020/01/24 21:05

raccy

総合スコア21735

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問