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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

3回答

672閲覧

JavaScriptでフィボナッチ数列を出したい

kenta666

総合スコア7

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2018/02/02 00:19

編集2018/02/02 00:22

前提・実現したいこと

JavaScriptでフィボナッチ数列を出したい。

発生している問題・エラーメッセージ

JavaScriptを学習しているのですが再帰処理のところでつまづいています。

function fib(pre, val, i, end) { console.log(pre) if( i < end ) { var temp = pre pre = val val = temp + val // koko←に1行15文字程度書いて正しく動かす } } fib(0, 1, 0, 10)

該当のソースコード

Javascript

1function fib(pre, val, i, end) { 2 console.log(pre) 3 if( i < end ) { 4 var temp = pre 5 pre = val 6 val = temp + val 7 // koko←に1行15文字程度書いて正しく動かす 8 } 9} 10fib(0, 1, 0, 10)

初歩的なところですがよろしくお願いします。

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

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

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

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

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

guest

回答3

0

Fibonacci 関数のそれぞれの実装 - Qiita

結論が公式一撃となんじゃそりゃみたいな感じですが、そのものズバリを執筆されている方が居るので紹介します。
実践ではどの程度を目指すかに寄りますが、再起→メモ化くらいが出来れば十分でしょう。
JSでフィボナッチ数列をそのまま使う要件なんて殆どないでしょうからね。

普通に書いたやつ

JavaScript

1var fib = function (it) { 2 if (it <= 1) return 1; 3 return fib(it - 1) + fib(it - 2); 4} 5var nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(fib); 6console.log(nums); 7// (10) [1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

メモ化バージョン

JavaScript

1var fib = (function(){ 2 var memoized = {}; 3 var fn = function (it) { 4 if (it <= 1) return 1; 5 if (!memoized[it]) memoized[it] = fn(it - 1) + fn(it - 2); 6 return memoized[it]; 7 } 8 return fn; 9})(); 10var nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(fib); 11console.log(nums); 12// (10) [1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

※1, 1, 2, 3...という風にしたければ、最初のif文をif (it <= 2)に変更すればそうなります。

投稿2018/02/02 02:02

miyabi-sun

総合スコア21158

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

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

0

例えばこんな.

JavaScript

1(function fib(m, n, i, end){ 2 i < end ? (console.log(i, n), fib(n, m + n, i + 1, end)) : null; 3})(0, 1, 0, 10);

投稿2018/02/02 00:45

defghi1977

総合スコア4756

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

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

0

ベストアンサー

フィボナッチ数

F(0) = 0,

F(1) = 1,
F(n + 2) = F(n) + F(n + 1) (n ≧ 0)

追記
pre = F(n)
val = F(n + 1)
i = n
end = 終わり

投稿2018/02/02 00:24

編集2018/02/02 00:38
Zuishin

総合スコア28660

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

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

kenta666

2018/02/02 00:40

早速の回答ありがとうございます。//のところに入る式も教えていただけるとありがたいです。(^-^;
Zuishin

2018/02/02 00:42

フィボナッチ数がどんなものか理解しさえすればわかります。
kenta666

2018/02/02 00:42

ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問