每日算法之:给定一个文件目录的路径,写一个函数统计这个目录下所有的文件数量并返回,隐藏文件也算,但是文件夹不算

题目

给定一个文件目录的路径,写一个函数统计这个目录下所有的文件数量并返回,隐藏文件也算,但是文件夹不算

方法思路

1.队列实现(广度优先搜索BFS)

  • 使用队列来按层级遍历目录结构
  • 从根目录开始,将其加入队列
  • 循环处理队列中的每个目录,列出其所有子项
  • 如果是文件,计数器加1;如果是目录,加入队列继续处理

2.栈实现(深度优先搜索DFS)

  • 使用栈来实现深度优先遍历
  • 从根目录开始,将其压入栈
  • 循环处理栈顶元素,列出其所有子项
  • 如果是文件,计数器加1;如果是目录,压入栈继续处理

代码实现

方法一:队列实现

 public static int countFileWithQueue(String path){
        File rootDir = new File(path);
        if(!rootDir.exists() || !rootDir.isDirectory()){
            throw new IllegalArgumentException("路径不存在或不是目录:" + path);
        }
        int count = 0;
        Queue<File> queue = new LinkedList<>();
        queue.add(rootDir);

        while (!queue.isEmpty()){
            File currentDir = queue.poll();
            File[] files = currentDir.listFiles();

            if(files != null){
                for (File file : files){
                    if(file.isFile()){
                        count++;
                    }else if(file.isDirectory()){
                        queue.add(file);
                    }
                }
            }
        }
        return count;
    }

方法二:栈实现

public static int countFileWithStack(String path){
        File rootDir = new File(path);
        if(!rootDir.exists() || !rootDir.isDirectory()){
            throw new IllegalArgumentException("路径不存在或不是目录:" + path);
        }
        int count = 0;
        Stack<File> stack = new Stack<>();
        stack.push(rootDir);
        while (!stack.isEmpty()){
            File currentDir = stack.pop();
            File[] files = currentDir.listFiles();
            if(files != null){
                for (File file : files){
                    if(file.isFile()){
                        count++;
                    }else if(file.isDirectory()){
                        stack.push(file);
                    }
                }
            }
        }
        return count;
    }
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值