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

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

新規登録して質問してみよう
ただいま回答率
85.31%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

1回答

1489閲覧

C#で再帰を使用して配列の組み合わせをすべて書き出したい

退会済みユーザー

退会済みユーザー

総合スコア0

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

0クリップ

投稿2022/03/14 07:48

編集2022/03/14 08:05

C#で再帰を使用して配列numberでできる1~配列数の組み合わせをすべて書き出したいと考えています。そのためグローバル変数でリストを作り、選んだ番数目の数字をリストに入れ、配列を最後まで参照したらリストをすべて書き出すという方式で実装しようとした15行目の書き出し部分で参照する数字が大きすぎるとエラーを吐かれました。
25行目のリストに入れる設定か12行目のprint_combinationの設定が間違っていると思うのですが、どう違うのでしょうか?教えてください。
もしくはもっと簡単な方法があれば教えてください。

C#

1using System.Collections.Generic; 2using System; 3 4public class Hello{ 5 public static List<int> intList = new List<int>(); 6 public static void Main(){ 7 int[] number={5,6,7,8,9}; 8 for(int i=0;i<number.Length;i++){ 9 combinations(number,number.Length,i); 10 } 11 } 12 static void print_combination(int n) 13{ 14 for (int i = 0; i < n; i++){ 15 Console.WriteLine(intList[n]); 16 } 17} 18 19static void comb_sub(int[] list,int n, int r, int m) 20{ 21 if (r == 0) 22 print_combination(m); 23 else if (n > 0) { 24 comb_sub(list,n - 1, r, m); 25 intList.Add(list[m]); 26 comb_sub(list,n - 1, r - 1, m + 1); 27 } 28} 29 30static void combinations(int[] list,int n, int r) 31{ 32 if (r > 0 && r <= n) comb_sub(list,n, r, 0); 33} 34}

エラー
Unhandled Exception:
System.ArgumentOutOfRangeException: Index was out of range. Must be non-negative and less than the size of the collection.

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

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

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

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

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

y_waiwai

2022/03/14 07:56

うまくいかないとはどういうふうになってうまくいかないんでしょうか
退会済みユーザー

退会済みユーザー

2022/03/14 08:00

15行目でリストの中身を書き出すときに参照する数字が大きすぎるとエラーを吐かれました
y_waiwai

2022/03/14 08:03

ならそれを質問文に追記しましょう。エラーメッセージも提示してください。
退会済みユーザー

退会済みユーザー

2022/03/14 08:31

> 15行目の・・・25行目のリストに入れる設定か12行目 質問に書かれたコードには行番号が振ってないので行番号で言われても他人には分からないということが分かりませんか?
fana

2022/03/14 08:56

組み合わせがどうの…という話に対して > List<int> intList というのがどういう形で結果を保持する話なのかがまずわからん. こいつを弄ってるのは > intList.Add(list[m]); という行だけと見えるが… 何やら再帰で延々と数値をAddしていく → ある時点で中身を先頭から表示する という処理でどうのようにして「組み合わせ」を表現するという話なのか? というのがわからん.
guest

回答1

0

mは最大nになるのに、intListのサイズは最大でrにしかならないので、out of rangeになります。
(nrcombinationsを呼び出した時点の値)
素直にintList.Countまでのループにしましょう。

いろいろ修正すると、このような感じでしょうか。

C#

1 static void print_combination() 2 { 3 for (int i = 0; i < intList.Count; i++) { 4 Console.Write(intList[i]); 5 } 6 Console.WriteLine(); 7 } 8 9 static void comb_sub(int[] list, int n, int r, int m) 10 { 11 if (r == 0) 12 print_combination(); 13 else if (r <= n) { 14 comb_sub(list, n - 1, r, m + 1); 15 intList.Add(list[m]); 16 comb_sub(list, n - 1, r - 1, m + 1); 17 intList.RemoveAt(intList.Count - 1); 18 } 19 }

投稿2022/03/14 20:38

編集2022/03/20 20:37
actorbug

総合スコア2479

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.31%

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

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

質問する

関連した質問