leetcode做题笔记71

给你一个字符串 path ,表示指向某一文件或目录的 Unix 风格 绝对路径 (以 '/' 开头),请你将其转化为更加简洁的规范路径。

在 Unix 风格的文件系统中,一个点(.)表示当前目录本身;此外,两个点 (..) 表示将目录切换到上一级(指向父目录);两者都可以是复杂相对路径的组成部分。任意多个连续的斜杠(即,'//')都被视为单个斜杠 '/' 。 对于此问题,任何其他格式的点(例如,'...')均被视为文件/目录名称。

请注意,返回的 规范路径 必须遵循下述格式:

  • 始终以斜杠 '/' 开头。
  • 两个目录名之间必须只有一个斜杠 '/'
  • 最后一个目录名(如果存在)不能'/' 结尾。
  • 此外,路径仅包含从根目录到目标文件或目录的路径上的目录(即,不含 '.''..')。

返回简化后得到的 规范路径

思路一:模拟题意

cpp 复制代码
char * simplifyPath(char * path){
    char *stack[100];
    int size = 0;
    for (char *s = strtok(path, "/"); s; s = strtok(NULL, "/")) {
        if (strcmp(s, ".") == 0) {
            //do nothing
        } else if (strcmp(s, "..") == 0) {
            //back 
            size = fmax(0, size-1);
        } else {
            stack[size++] = s;
        }
    }
    if (size == 0) return "/";
    char *res = calloc(1000, sizeof(char));
    for (int i=0; i<size; ++i) {
        strcat(res, "/");
        strcat(res, stack[i]);
    }
    return res;
}

时间复杂度O(n),空间复杂度O(n)

分析:

本题将绝对路径改为规范路径,即判断是否有"."".."这些特殊的字符,对相应字符情况进行处理,利用栈先进后出的特点,将字符输入栈中进行判断。

总结:

本题考察对字符串的应用,考虑是否有"."".."这些特殊的字符再处理即可得到答案

相关推荐
黎宇幻生2 小时前
Java全栈学习笔记39
java·笔记·学习
遇印记6 小时前
大二java学习笔记:二维数组
java·笔记·学习
bnsarocket7 小时前
Verilog和FPGA的自学笔记6——计数器(D触发器同步+异步方案)
笔记·fpga开发·verilog·自学·硬件编程
LK_079 小时前
【Open3D】Ch.3:顶点法向量估计 | Python
开发语言·笔记·python
li星野9 小时前
打工人日报#20251011
笔记·程序人生·fpga开发·学习方法
摇滚侠9 小时前
Spring Boot 3零基础教程,yml配置文件,笔记13
spring boot·redis·笔记
QT 小鲜肉9 小时前
【个人成长笔记】在Ubuntu中的Linux系统安装 anaconda 及其相关终端命令行
linux·笔记·深度学习·学习·ubuntu·学习方法
QT 小鲜肉9 小时前
【个人成长笔记】在Ubuntu中的Linux系统安装实验室WIFI驱动安装(Driver for Linux RTL8188GU)
linux·笔记·学习·ubuntu·学习方法
急急黄豆9 小时前
MADDPG学习笔记
笔记·学习
Chloeis Syntax10 小时前
栈和队列笔记2025-10-12
java·数据结构·笔记·