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

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

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

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

Q&A

解決済

1回答

4557閲覧

樹形図をたどる、重複する組み合わせはスキップしたい

akamakku

総合スコア191

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

0グッド

0クリップ

投稿2016/07/06 13:31

編集2016/07/06 13:40

ある重複のある数列から任意の個数の、ある条件にあった数字を取り出す組み合わせを、樹形図をたどるようなアルゴリズムをつかって列挙したいんです。

その際に、重複した組み合わせが出力されそうなときにその出力をスキップしたいんです。
つまり、ただ樹形図をたどって出力していると同じ組み合わせが複数回出力されてしまうことになると思うのですが、いままでで出力してある場合は出力したくないんです。

樹形図を辿って出力するだけのプログラムはできたんですが、いままで出たことがあるのか判定することはできるんでしょうか?

(追記)
組み合わせの総数を単純に計算すると15000位になってしまって、ハッシュ値みたいのものを保存しておいて、検索するようなことは厳しいです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

javaならArrayListがあるので、

java

1ArrayList<Data> datalist = new ArrayList<Data>();//表示した過去データを格納 2tree = [樹形図]// 3 4for(tree???){//樹形図のデータを取り出すループ 5 Data data = [tree樹形図のデータ] 6 boolean flag = true; 7 for(int n = 0; n < datalist.size(); n++){ 8 if(data.equals(datalist.get(n))){//過去のものと重複した 9 flag = false;//表示しない 10 break; 11 } 12 } 13 if(flag){//重複がなかった 14 System.out.print(data); 15 datalist.add(data); 16 } 17}

みたいに過去に表示したものとの一致を検出するのはどうでしょうか。
データが増えるとパフォーマンスがどんどん下がる方式だとは思います。

投稿2016/07/06 13:47

intelf___

総合スコア868

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

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

akamakku

2016/07/06 13:50

やっぱりそういうシンプルなものになってしまいますか~ とりあえずそれでやってみようかなと思います。
退会済みユーザー

退会済みユーザー

2016/07/06 16:47

ArrayListよりもHashSetがおすすめです。 HashSetは同じ要素を複数格納できないという制約がある上に、ハッシュを使った検索も内部で行っています。 また、重複の検索には、HashSet#containsを使えばよいでしょう(ArrayListにもcontainsがあるのですが)。
swordone

2016/07/06 16:50

HashSetを使うならcontainsを使わずとも、addすればいいだけだと思います。 すでに同じ要素があればSetは変化しません。
intelf___

2016/07/07 00:39

気になって調べてみましたがHashSet#addはよさそうですね 勉強になります。 重複なしだと戻り値がtrueになるので if(hashSet.add(data)) System.out.print(data); みたいな文ができそうですね。
akamakku

2016/07/13 05:53

HashSet !! まさにいまの自分のためにできたんじゃないかというようなクラスです!笑 コメントしてくださった皆さんも含めてBAです ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問