Java LinkedHashMap | #简单错误记录#
简单错误记录
https://www.nowcoder.com/practice/2baa6aba39214d6ea91a2e03dff3fbeb
import java.util.LinkedHashMap;
import java.util.Scanner;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
// 注意 hasNext 和 hasNextLine 的区别
LinkedHashMap<String,Integer> map = new LinkedHashMap<>();
while (in.hasNextLine()) { // 注意 while 处理多个 case
String line = in.nextLine();
if(line.equals(""))break;
String[] line_s = line.split(" ");
String[] fn_s = line_s[0].split("\\\\");
int is_cut = fn_s[fn_s.length-1].length() - 16;
String fn_16 = is_cut>0 ? fn_s[fn_s.length-1].substring(is_cut) : fn_s[fn_s.length-1];
String key = fn_16 + " " + line_s[1];
map.put(key, map.getOrDefault(key, 0) + 1);
}
while(map.size()>8){
map.remove(map.keySet().iterator().next());
}
for(String key : map.keySet()){
System.out.println(key + " " +map.get(key));
}
}
}
HashMap不一定能保存put的顺序
LinkedHashMap是一个有序的HashMap,可以按照插入顺序遍历元素
#24届暑假实习#

