
再帰処理に関する質問をさせていただきます。私は今複数のarraylistの中に入っているオブジェクトを順列を用いてすべての並びを所得するプログラムを作っています。プログラムが長く汚いので(汗)、例で示させていただきます。
(例)
ArrayList t1;
ArrayList t2;
t1の中身[obj1,obj2]
t2の中身[obj3,obj4]
結果:以下のように4つオブジェクトを作成
[obj1,obj3],[obj1,obj4],[obj2,obj3],[obj2,obj4]
それに伴い、メソッドを作り再帰呼び出しを行っているんですが、returnでメインに返りません。戻り値はvoidです。また、
return;
System.out.println("check");
と書くと、checkが出力されてしまっています(しかも何個も)。IndexOutOfBoundsExceptionのエラーがでるのですが、先にreturnを処理するはずなのになぜだろうと悩んでいます。
return以外にメインに戻る方法はあるんでしょうか?またreturnでメインに戻らない理由を知っている方がいるなら、ぜひ教えていただきたいです。よろしくお願いします。
A 回答 (2件)
- 最新から表示
- 回答順に表示

No.2
- 回答日時:
全体の流れが見えないので、なんとも言えませんが……、
特に何個もcheckが出力されてしまうという辺りは状況の想像がまったくつきません。また2つのListの順列処理に再帰を持ち出すところもピンときませんが……、
1ついえることは――、
自分の中で自身の関数を呼び出すことを「再帰処理」といいます。そうして、return は「呼び出し元」に戻る、です。
呼び出し元がmainならmainへ、です。
でも、mainからsubfuncを呼んで、そのsubfuncの中でsubfuncを呼んで、そこでreturnされるとsubfuncの続きへ、んで、その続きでもう一度returnされて、やっとmainへと帰り着きます。
returnでメインに戻らない理由は、再帰呼び出しをしたため、returnしても自身に戻っただけだから、なのではありませんか?
再帰呼び出しを重ねた深層部で、一気にmainまで戻りたければ、戻り値をbooleanにして、trueになると連鎖的にreturnしていくように作ればOKです。その場合、再帰呼び出しの箇所は、たとえば、以下のようになるでしょう。
if (subfunc(...)) return true;
No.1
- 回答日時:
> return以外にメインに戻る方法はあるんでしょうか?
メソッドの最後まで実行し終えるか、例外が投げられると戻りますが、今回は関係なさそうですね。
> returnでメインに戻らない理由
return が実行されたのに戻らないということはありえないので、return が実際には実行されていないというのが原因になります。つまり、処理の流れがおかしくなっているということです。
それにしても、プログラムが長いというのが気になりますね。単純な順列の列挙を再帰でやるなら 20 行足らずで書けると思うんですよ。アルゴリズムについてもう一度考え直してみてはどうでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Javaプログラムからポップアッ...
-
tryの終了
-
onBlurとonFocusの処理順序につ...
-
交互にスレッド実行 (どうして...
-
ブラウザを閉じた後のサーバ側...
-
Tomcatのスレッドを破棄する方法
-
[Java] while(true)の意味
-
javaのプログラムが止まる
-
JSPで「処理中」をブラウザに表示
-
アコーディオンメニューをアン...
-
Tomcat高負荷時の設定について
-
ftp 同時複数接続の負荷テスト...
-
ExcelVBA で文字列の特定の文字...
-
「タイプ初期化子が例外をスロ...
-
エクセルVBAで、条件に一致する...
-
変数名の付け方
-
private static という変数の修飾
-
レコード件数の表示
-
クラス間でのデータ参照
-
パワーポイントのVBAでテキスト...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ラジオボタンの選択判定
-
Javaプログラムからポップアッ...
-
[Java] while(true)の意味
-
Javaでのデバッグコード削除
-
tryの終了
-
doGetとdoPostの違い
-
数値の定数を付ける時
-
onBlurとonFocusの処理順序につ...
-
BLOB型の画像データを表示したい
-
ラベルの表示までが異常に遅い...
-
1日の始まりを合図する
-
javaのプログラムが止まる
-
C#で別スレッドの終了を知りたい
-
Tomcat高負荷時の設定について
-
表示待ち時間に「処理中...」の...
-
どうコーディングしたらよいの...
-
マルチスレッドのデバッグ
-
ExcelVBA で文字列の特定の文字...
-
スレッド1とスレッド2を交互に...
-
Servletのスレッドを終了させたい
おすすめ情報