5
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

フィボナッチ数を出力する関数を作る

Last updated at Posted at 2018-08-27

再帰関数を書いた事がなかったので、とりあえずフィボナッチ数が適しているだろうと思って書いてみました。
再帰関数という名前に身構えてしまいましたが、意外とシンプルですね。

function F (n) {
  if ( n === 0 || n === 1 ) {
    return 1;
  } else {
    return F(n-1) + F(n-2);
  }
}

ワンライナー

F = (n) => n === 0 || n === 1 ? 1 : F(n-1) + F(n-2);

こんな感じの書き方は冗長な感じがしているので、よりよい書き方を知っている方は是非コメントをよろしくお願いします:pray:

[追記]
コメントでより短いやり方を教えていただきました。
const fib = n => n > 2 ? fib(n - 1) + fib(n - 2) : 1;
基底部のところを後回しにするのがポイントですね。

参考

JavaScript-階乗でみる、初めての再帰関数

5
4
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?