388. [LeetCode]Longest Absolute File Path

这道题给我最大的启示就是,做题之前!!一定要!决定要!先弄懂需求,分析需求!!

一定要对要求明确!!

// 文件名 至少一有一个点和后缀
// 目录名 不能含有点

public class Solution {
    public int lengthLongestPath(String input) {
        String[] strs = input.split("\n"); 
        int size = strs.length;

        int[] array = new int[size]; // max is size
        int maxlev = 0;
        //
        for(int i=0;i<size;i++){
            int lev = NumsOfT(strs[i]);
            array[i] = lev;
            if(lev > maxlev) maxlev = lev;
        }

        int[] lengths = new int[size];
        int[] maxSum = new int[maxlev+1];

        maxSum[0] = strs[0].length();
        lengths[0] = strs[0].length();

        if(size == 1) return maxSum[0];

        for(int i=1;i<size;i++){
            int lev = array[i]; 
            maxSum[lev] = maxSum[lev-1]+strs[i].length()-lev+1;
            if(strs[i].contains("."))
            lengths[i] = maxSum[lev];
        }

        //
        int maxlength = 0;
        for(int i=0;i<size;i++){
            if(maxlength < lengths[i]) maxlength = lengths[i];
        }

        return maxlength;
    }

    private int NumsOfT(String str){
        // this spacial tab must kown
        int i = 0;
        // int j = 1;
        int size = str.length();

        char[] charStr = str.toCharArray();
        int count = 0;
        while(i < size){
            if(charStr[i] == '\t'){  // Point!!!
                count++;
                i++;
            } else {
                break;
            }
        }
        return count;
    }
}

这道题,我的没有过4空格的测试样例

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值