グラフを幅優先探索であれやこれやしたいのですが、キューにグラフの座標をしまいたいです。
つまり頂点を1, 2と番号で管理ではなく、(1, 4) (2, 3)などと座標で管理したいのですが
javaではキューにどのように格納すればいいでしょうか
queue.add(1)とはできますが
二つの値を同時に格納はどうやるのでしょうか
javaにはタプルはないと聞きます
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答4件
0
ベストアンサー
「座標」という1つの意味を持った値なので、それ専用のクラスを作る、というのがいい気もします。
java
1class Point{ 2 public int x; 3 public int y; 4}
ごく簡単なクラスで、値の整合性を考える必要もないでしょうし、フィールドをpublic
にする手抜きな形で十分だと思います。
投稿2018/05/29 07:24
総合スコア145184
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
タプルクラスを作るならこんな感じでしょうか。
座標しか扱わないなら座標クラスとした方が良いかもしれません。
Java
1public class Main 2{ 3 public static void main(String[] args) { 4 Queue<Tuple<Integer, Integer>> queue = new ArrayDeque<>(); 5 6 queue.add(new Tuple<>(1, 4)); 7 queue.add(new Tuple<>(2, 3)); 8 9 System.out.println(queue.poll()); 10 System.out.println(queue.poll()); 11 } 12} 13 14public class Tuple <T1, T2> 15{ 16 public final T1 first; 17 public final T2 second; 18 19 public Tuple(T1 first, T2 second){ 20 this.first = first; 21 this.second = second; 22 } 23 24 @Override 25 public String toString() { 26 return "(" + first + ", " + second + ")"; 27 } 28}
投稿2018/05/29 07:23
総合スコア630
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
Javaでのtupleの利用であれば、こちらのライブラリを使うのはいかがでしょうか?
- org.apache.commons.lang3.tuple
使い方はWebで調べると出て来ますが、他の言語にあるようなtupleと同じように使えそうです。
http://akira1908jp.hatenablog.com/entry/20110820/1313853744
今回のケースにあたっては、座標を管理するクラスを定義し、そのクラスをキューに格納することが出来そうですね。
投稿2018/05/29 07:22
総合スコア2335
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
二つの値を同時に格納はどうやるのでしょうか
HashMapを使うのはどうですか? HashMapを使うと2つのデータをセットにすることができます。
詳しくはHashMapをご覧ください。
投稿2018/05/29 07:19
退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/05/29 07:21
2018/05/29 07:50
退会済みユーザー
2018/05/29 07:52
2018/05/29 07:55
退会済みユーザー
2018/05/29 08:01
退会済みユーザー
2018/05/29 08:03
2018/05/29 08:08
退会済みユーザー
2018/05/29 10:00
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。