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届暑假实习#
全部评论

相关推荐

点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务