JAVAはリスト集合の中で最も繰り返し回数の多い文字列と回数を探し出す
2009 ワード
, , 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