zoukankan      html  css  js  c++  java
  • 远景面试算法题——FolderSize

    描述

    文件被存储在磁盘上的时候,通常为cluster方式。每个cluster具有固定的大小,一个文件所消耗的空间量始终是cluster大小的整数倍。因此,如果cluster的大小为100字节,165字节的文件将会使用实际使用200字节的存储空间,造成35个空间的浪费。

    一个folder会有多个file,每个file单独计算浪费空间;如果某个folder没有出现,浪费空间为0

    定义

    Method signature: int[] calculateWaste(String[] files, int folderCount,int clustersize)

    输入参数说明:

    files为输入的folder编号和对应的file大小的数组。例如{"0 55","0 47"},表示为folder 0 下面有两个文件,大小分别为55和47,按空格分隔。

    folderCount为所有的folder个数。当folderCount为3的时候,会有0,1,2三个folder编号,clustersize为固定块大小。

    返回值:每个folder对应的浪费空间大小

    测试用例

    files={"0 55","0 47","1 22","1 21"}。foldercount=3,clustersize=50

    Returns:{48,57,0}

     

    ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

    解题之前先安利两首歌《安河桥》《七月上》

     

    今天面试之前包夜导致自己两眼昏花,看题目费解到半死(我发四我再也不会包夜了!)。让20min写出来,后来发现其实并不难。当然代码是否有误还要斟酌

    核心:把字符串转换成数字 

     

    int * calculateWaste(string* files,int folderCount,int clustersize){
        int* waste=new int[folderCount];
        int filenum=sizeof(files)/sizeof(files[0]);
        int folderid=0,filesize=0;
        string temp;
    
        if(files==NULL||folderCount==0||clustersize==0){
            cout<<"参数错误"<<endl;
            return waste;
        }
        for(int i=0;i<filenum;i++){
            temp=files[i];
            int j=0;
            while(temp[j]!=' '){   //计算folderID
                folderid=folderid*10+temp[j]-'0';
                j++;
            }
            j++;   //跳跃空格
    
            while(j<temp.length()){
                filesize=filesize*10+temp[j]-'0';
                j++;
            }
            waste[folderid]+=(filesize/clustersize+1)*clustersize-filesize;
            folderid=0;
            filesize=0;  //再次扫描下一个file前清空之前的数据
        }
        return waste;
    }

    代码如上。为了面试官看的清楚,我还从新誊写了一份,然而···不说了。

    关于这道题和同学讨论了一下:

    1.要不要释放内存,事实上,是不用的。因为返回的内存必然是有用的,你以后要用的,所以不需要释放内存。当程序运行完毕,系统会为你做这个释放。

    那关于动态申请的内存一定要记得释放是用于什么情况呢?在类中,如果你定义一个类,类中有动态申请的内存,在你的析构函数里一定要释放内存。(不知道我这种观点是否有误?)

    2.还有关于string [] files,我用sizeof(files)/sizeof(files[0])这种方法求数组长度是基于每个元素是等长的,那如果string数组不等长了我要怎么求得长度呢?这个时候应该给出【长度参数】

     

    --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

    面试的时候有些问题我真的没有考虑过,所以答的并不好:

    1.为什么考seu,意思是怎么没保研

    2.为什么不继续做QA(QA事实上也很难,也要求很高的技术,TDD--Testing Driven Develope)

    3.自己写的算法代码一定要将细一点,最好分【多个函数】完成功能

    4.BAT投了吗,结果如何(内心OS:这种问题我真的不知道怎么回答啊!!)

     

  • 相关阅读:
    python list添加元素的几种方法
    Python ---- list和dict遍历
    python 之 collections
    python list 中元素的统计与排序
    pandas dataframe 读取 xlsx 文件
    Python 缓存机制与 functools.lru_cache(zz)
    pip 使用
    python 中的异常处理
    python 时间日期处理
    python read txt file
  • 原文地址:https://www.cnblogs.com/LUO77/p/5425740.html
Copyright © 2011-2022 走看看