ArrayListの中にある重複した要素の全てのindexを
取得したいのですが
どうしたらいいのでしょうか?
教えていただきたいです
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。

回答1件
0
ベストアンサー
こんにちは。
愚直な方法ですが、リストの全要素についてループさせて、リストの要素をキーとし、その要素の位置のリストを値とするマップを作って、位置のリストの長さが 1 より大きいものを一覧すればよいでしょう。
サンプルとして以下のコードは、大文字小文字問わずA
からE
までのアルファベットのいずれかによって構成される、長さ3の文字列をランダムに1000個生成してArrayList
に入れ、これに対して上記のロジックで重複した要素の全てのインデクスを表示するものです。
(※ランダムな文字列を作るために、Apache Commons Lang のRandomStringUtils を使っています。)
java
1import java.util.List; 2import java.util.ArrayList; 3import java.util.Map; 4import java.util.HashMap; 5import org.apache.commons.lang3.RandomStringUtils; 6 7public class Q139769 { 8 9 private final static int LIST_SIZE = 1000; 10 11 private static List<String> getRandomStringList() { 12 List<String> list = new ArrayList<>(); 13 for (int i=0; i < LIST_SIZE; ++ i) { 14 list.add(RandomStringUtils.random(3, "ABCDEabcde")); 15 } 16 return list; 17 } 18 19 public static void main(String args[]) { 20 List<String> list = getRandomStringList(); 21 Map<String, List<Integer>> map = new HashMap<>(); 22 23 for (int i = 0; i < LIST_SIZE; i++) { 24 String str = list.get(i); 25 List<Integer> indexes = map.get(str); 26 if (indexes == null) { 27 indexes = new ArrayList<Integer>(); 28 map.put(str, indexes); 29 } 30 indexes.add(i); 31 } 32 33 for(Map.Entry<String, List<Integer>> entry : map.entrySet()) { 34 List<Integer> indexes = entry.getValue(); 35 if (indexes.size() > 1) 36 System.out.println(entry.getKey() + ": " + entry.getValue()); 37 } 38 } 39}
なお、上記のコードを、jdoodle.com/a/B0r にも上げました。(Executeボタンをクリックすると実行されます)
以上参考になれば幸いです。
投稿2018/08/05 20:53
編集2018/08/05 21:30総合スコア9058
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。