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

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

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

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

Q&A

1回答

721閲覧

javascript 再帰呼び出し(再帰関数)について

RMBQsKe5AP10gjx

総合スコア24

JavaScript

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

0グッド

1クリップ

投稿2019/04/22 10:28

編集2019/04/23 03:35

ご覧いただきありがとうございます。
現在wshのjscriptで再帰関数を理解しようと奮闘しています。
そこで、現在のフォルダを¥マークで区切り、
配列に入れて一階層ずつ画面に表示するプログラムを作り、練習をしようとしました。
しかし、スタック領域が不足していますと表示され、うまくいきません。
そもそも理解できていないのですが、どのように直せばよろしいでしょうか。
お忙しいところ恐縮ですが、ご教示願います。

var

1var name = WScript.ScriptFullname; 2var words = name.split('\') 3function test(i){ 4if(i > words.length){ 5return 1; 6} else { 7WScript.echo(words[test(i)]) 8} 9} 10test(words.length) 11 12コード

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

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

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

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

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

otn

2019/04/22 13:25

漢字を間違えてるあたり、再帰呼び出しについての理解が十分でない気がします。 コードを見てもそう思います。先に進まず、勉強し直しては?
RMBQsKe5AP10gjx

2019/04/23 03:30

再帰呼び出しですね。打ち間違いです。その通りです。ありがとうございます。
guest

回答1

0

気になる点はいくつかありますが・・・

スタック領域が不足しての原因は、

iの値が変化しないので、test(i)を無限に呼ぶようになっています。

if(i > words.length){ return 1; } else { WScript.echo(words[test(i)]) ← iが変化しないなら、if(i > words.length)はずっとelse節を通る }

投稿2019/04/22 10:49

momon-ga

総合スコア4820

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

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

RMBQsKe5AP10gjx

2019/04/22 10:56

ありがとうございます。 そういうことだったのですね。 コードがおかしいのは重々承知でしたが、 ありがとうございます。 試しにi-1にしてみましたが、同じエラーになってしまいました。
gogojp

2019/04/22 12:08

iがwords.lengthより大きいときに1を返すわけですから、elseに入るということはiがwords.length以下であるからです。それなのにWScript.echo(words[test(i - 1)])というふうにi - 1にしたところでiがwords.length以下であることは変わらないのでエラーになります。 なのでi + 1とかにすればエラーは出ないです。
RMBQsKe5AP10gjx

2019/04/22 12:20

ありがとうございます! たしかにエラーはでなくなりました。感謝です。 しかし、一つしか表示されません。
gogojp

2019/04/22 13:01

関数を実行するとその関数はスタックというデータを貯めとく箱のようなものに積み重ねていきます。 コンピュータはスタックに積み重なったデータを順に取り出し処理していきます。 しかし、再帰関数を使うと関数が自分自身を呼び出して無限にスタックにデータが積み重なります。 そしてスタックには限界があるので、その限界を超えることでスタック不足というエラーになっていまいます。 const num = 1000; function test(n) { console.log(n); if (n > num) { return; } else { test(n + 1); } } test(0); 例えばこのようなプログラムならスタック不足にならずに再帰関数を実感することができます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問