JAVAはリスト集合の中で最も繰り返し回数の多い文字列と回数を探し出す


           ,          ,   N   1  。
public class Test{
  public static void main(String[] args) {
    List list = new ArrayList<>();
    List list2 = new ArrayList<>();
    Map map = new HashMap<>();

    list.add("www.baidu.com");
    list.add("www.zhonghao.com");
    list.add("www.xiaojie.com");
    list.add("www.dumeng.com");
    list.add("www.baidu.com");
    list.add("www.zhonghao.com");
    list.add("www.xiaojie.com");
    list.add("www.dumeng.com");
    list.add("www.zhonghao.com");
    list.add("www.xiaojie.com");
    list.add("www.xiaojie.com");
    list.add("www.xiaojie.com");
    int count = 0;

    //     list2  
    for (int i = 0; i < list.size(); i++) {
      for (int j = i + 1; j < list.size(); j++) {
        if (list.get(i).equals(list.get(j))) {
          list2.add(list.get(i));
          break;
        }
      }
    }

    //  list2           ,    Map  
    for (String obj : list2) {
      if (map.containsKey(obj)) {
        count++;
        map.put(obj, map.get(obj) + 1);
      } else {
        map.put(obj, 1);
      }
    }
  
    list2.clear();


    Iterator> it = map.entrySet().iterator();
    while (it.hasNext()) {
      Map.Entry entry = it.next();
      if (entry.getValue() == count) {
        list2.add(entry.getKey());
        // System.out.println("key=" + entry.getKey() + "," + "value=" + entry.getValue());
      }
    }
    if (list2.size() > 1) {
      System.out.println(list2 + "        ,     :" + (count + 1) + " ");
    }
    if (list2.size() == 1) {
      System.out.println("        :" + list2 + ",     :" + (count + 1) + " ");
    }
  }
}

出力結果:
        :[www.xiaojie.com],     :5