华为OD面试即兴笔试算法(一)

这篇博客分享了华为OD面试中的一道算法题,要求在视频面试中现场解决。题目涉及遍历文件夹,根据文件后缀分类,并对结果进行排序,重点考察临场编程能力。
摘要由CSDN通过智能技术生成

简述

该题目为华为OD面试第四轮,一位技术主管视频面试时,最后即兴出的一道算法题;当时是使用电脑端的zoom进行视频面试,算法题可以使用电脑的IDE,需要进行屏幕共享;难度中下,更倾向于考验临场发挥能力。

题目描述

遍历某个文件夹下的所有的文件,获取所有的文件名,根据文件后缀分类;并对分类与 文件名都进行任意一种排序;

解题参考
    @Test
    public void classifyFiles() {
        File originFile = new File("e:\\");
        List<String> fileNames = getFileNames(new ArrayList<>(), originFile);
        Collections.sort(fileNames);
        //直接使用TreeMap,自动排序
        Map<String, List<String>> map = new TreeMap<>();
        fileNames.forEach(fileName -> {
            String ex = fileName.substring(fileName.lastIndexOf(".") + 1);
            if (!map.keySet().contains(ex)) {
                map.put(ex, new ArrayList<>());
            }
            map.get(ex).add(fileName);
        });
        System.
  • 8
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值