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届暑假实习#