JAVA找出List集合中重复次数最多的字符串和次数

下面的这种逻辑比较冗余,可以参考下一篇的代码,只要将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次

你可能感兴趣的:(算法的学习)