获取最小文件的大小

有两个API接口,一个是获取当前目录下所有的文件及其子目录列表的函数 getFilesList() 一个是获取某个文件大小的函数getFileSize() 求这个文件夹下占用空间最小的那个文件。

深度优先策略和广度优先策略

深度优先:只要目录下有子目录就一直递归到无子目录,然后分别计算该目录下的所有文件大小,最后回溯至上一目录继续此操作。

广度优先:优先计算出此目录下所有文件的大小,再进入到下一子目录。具体实现方式是维护一个队列,将文件初始路径插入,赋值给临时变量后将该路径弹出,并判断此路径是否是目录,是的话就优先将此目录下的所有文件计算大小,然后再继续走子目录。

深度优先代码:

#include <iostream>
#include <dirent.h>
#include <sys/stat.h>
#include <vector>
#include <limits.h>
#include <string.h>
#include <string>

// 获取文件大小
off_t getFileSize(const std::string& filePath) {
    struct stat fileStat;
    if (stat(filePath.c_str(), &fileStat) == 0) {
        return fileStat.st_size;
    } else {
        std::cerr << "Error getting file size." << std::endl;
        return 0;
    }
}

// 递归遍历目录,获取文件列表
void getFilesList(const std::string& directory, std::vector<std::string>& fileList) {
    DIR* dir;
    struct dirent* dirent;
    dir = opendir(directory.c_str());
    if (dir != nullptr) {
        while ((dirent = readdir(dir))) {
            std::string fileName = dirent->d_name;
            if (fileName == "." || fileName == "..") {
                continue;
            }
            std::string filePath = directory + "/" + fileName;
            struct stat fileStat;
            if (stat(filePath.c_str(), &fileStat) == 0 && S_ISDIR(fileStat.st_mode)) {
                // 若是子目录,则递归遍历
                getFilesList(filePath, fileList);
            } else {
                // 若是文件,则添加到文件列表
                fileList.push_back(filePath);
            }
        }
        closedir(dir);
    } else {
        std::cerr << "Error opening directory." << std::endl;
    }
}

// 获取最小占用空间的文件路径
std::string getSmallestFile(const std::vector<std::string>& fileList) {
    std::string smallestFile;
    off_t smallestSize = INT_MAX;

    for (const auto& file : fileList) {
        off_t fileSize = getFileSize(file);
        if (fileSize < smallestSize) {
            smallestSize = fileSize;
            smallestFile = file;
        }
    }

    return smallestFile;
}

int main() {
    std::string directoryPath = "your_directory_path_here";

    std::vector<std::string> fileList;
    getFilesList(directoryPath, fileList);

    std::string smallestFile = getSmallestFile(fileList);

    if (!smallestFile.empty()) {
        std::cout << "Smallest file: " << smallestFile << std::endl;
        std::cout << "Size: " << getFileSize(smallestFile) << " bytes" << std::endl;
    } else {
        std::cout << "No files found." << std::endl;
    }

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

久菜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值