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

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

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

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

Q&A

1回答

2076閲覧

javascriptの再帰が分かっていなかった模様です

summer_slt_turn

総合スコア14

JavaScript

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

0グッド

0クリップ

投稿2015/01/06 17:52

こんにちは
前に再帰について質問したのですが曖昧で分かったつもりになっていたようです。ネットで調べるとwhileで書かれたものとそれが解説サイト載っていたのですが、考えてもわかりません。

lang

1function factorial(num) 2{ 3 // If the number is less than 0, reject it. 4 if (num < 0) { 5 return -1; 6 } 7 // If the number is 0, its factorial is 1. 8 else if (num == 0) { 9 return 1; 10 } 11 // Otherwise, call this recursive procedure again. 12 else { 13 return (num * factorial(num - 1)); 14 } 15} 16 17var result = factorial(8); 18document.write(result); 19 20// Output: 40320

whileで書かれたもの

lang

1function factorial(num) 2{ 3 // If the number is less than 0, reject it. 4 if (num < 0) { 5 return -1; 6 } 7 // If the number is 0, its factorial is 1. 8 else if (num == 0) { 9 return 1; 10 } 11 var tmp = num; 12 while (num-- > 2) { 13 tmp *= num; 14 } 15 return tmp; 16} 17 18var result = factorial(8); 19document.write(result); 20 21// Output: 40320 22

while (num-- > 2)の間の処理のtmp = numはtmp=tmpnumですが
while(num-- > 2)の前の一行var tmp = num;
tmp = num;はnum--なのでtmp = 77になりtmp=49
その後496、その結果5、その結果4、その結果3でその後numが2になるのでwhileから抜け出しtmp = その結果*3を返すのではないのでしょうか?

しかしやってみると計算結果が合わなかったので最初のtmp = 77を87にしてみると合いました。

そこで疑問なのですが、whileの前のvar tmp = num;とwhile (num -- > 2)の8から1引いたnumは別物なんでしょうか?

そして返したtmp = 20160がどこに行くのかわかりません
個人的な推測ではこのサンプルの結果が40320なので20160を返したあとにnum--の結果numの2を呼び出し分岐させて、どれにもあわないので20160と掛け算をして終了なのかなと思うのですが、どうにも納得できません。

それ以前に変数に再代入した結果が変わるというのもどこでそうなっているのかが理解できてないのかもしれません
結局再帰も理解できてないのでしょうか?これは。
じぶんの頭の悪さに嫌気がさすのですが、好きなのでやってます

初歩的な質問なのですが教えてください

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

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

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

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

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

guest

回答1

0

後置デクリメント演算子(--)による演算は、値を評価した後で減算します。
ですので、下記と同じ動作になります。

lang

1 while (num > 2) { 2 num -= 1; 3 tmp *= num; 4 }

よって、20160 * 2を行って、結果が40320になります。

lang

1 // num == 3の時点 2 while (num-- > 2) { // num == 3, tmp == 20160 3 tmp *= num; // num == 2, tmp == 40320 4 } 5 // num == 2の時点 6 while (num-- > 2) { // num == 2, ループ終了 7 tmp *= num; // 処理されない 8 }

(2015-01-19: 2番目に--が付いていなかったのを訂正)

おまけ:console.logを使って状態を出力させるバージョンです。

lang

1function factorial(num) { 2 if (num < 0) return -1; 3 else if (num == 0) return 1; 4 5 var tmp = num; 6 while (num > 2) { 7 console.log("1: num=" + num); 8 num--; 9 console.log("2: num=" + num); 10 tmp *= num; 11 console.log("3: tmp=" + tmp); 12 } 13 console.log("4: tmp=" + tmp); 14 return tmp; 15} 16 17var result = factorial(8); 18console.log("5: result=" + result);

投稿2015/01/07 01:37

argius

総合スコア9388

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問