• Leetcode71. 简化路径


    题目传送地址: https://leetcode.cn/problems/simplify-path/

    运行效率
    在这里插入图片描述

    代码如下

     public static String simplifyPath(String path) {
            //因为一个.表示当前目录本身,所以可以直接忽略
            while (path.contains("/./")) {
                path = path.replace("/./", "/");
            }
            //     '//'都被视为单个斜杠 '/'     任意多个连续的斜杠(即,'//')都被视为单个斜杠 '/'
            while (path.contains("//")) {
                path = path.replace("//", "/");
            }
            if (path.endsWith("/.") && path.length() > 2) { //  因为要考虑到 path= /.
                path = path.substring(0, path.length() - 2);
            }
            //此外,两个点 (..) 表示将目录切换到上一级(指向父目录)
            while (path.contains("/../")) {
                // //不能盲目的说遇到..就进行处理。 因为...里也包含..    而...是可以为一个文件夹的名字  任何其他格式的点(例如,'...')均被视为文件/目录名称。
                StringBuilder stringBuilder = new StringBuilder(path);
                int indexOf = path.indexOf("/../");
                int lastIndexOf = path.lastIndexOf("/", indexOf - 1);
                if (lastIndexOf != -1) {
                    stringBuilder.delete(lastIndexOf, indexOf + 3);
                } else {
                    stringBuilder.delete(indexOf, indexOf + 3);
                }
                path = stringBuilder.toString();
            }
            if ("/".equals(path)) {
                return "/";
            }
            if (path.endsWith("/")) {
                path = path.substring(0, path.length() - 1);
            }
            if (path.endsWith("/..") && path.length() > 3) { //  因为要考虑到 path= /..
                int i = path.lastIndexOf("/", path.length() - 4);
                path = path.substring(0, i);
                if ("".equals(path)) {
                    return "/";
                }
            }
            if (path.endsWith("...")) {
                return path;
            }
            if ("/..".equals(path)) {
                return "/";
            }
            if (path.endsWith(".")) {
                path = path.substring(0, path.length() - 1);
            }
            return path;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
  • 相关阅读:
    芯科科技推出新的8位MCU系列产品,扩展其强大的MCU平台
    tcp,udp和计算机协议分层
    Pytest测试中的临时目录与文件管理!
    常见的音频知识
    国家开放大学 模拟试题 训练
    二叉树--后缀表达式转二叉树
    拓端tecdat|R语言使用K-Means聚类可视化WiFi访问
    Lambda表达式(附有案例)
    【数据结构】堆的应用 -- 堆排序和TopK问题
    Mongodbd的简学
  • 原文地址:https://blog.csdn.net/qq_40241957/article/details/126097770