Leetcode 71. 简化路径题解

Leetcode 71. 简化路径——栈

题目链接:简化路径

题目描述

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

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

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

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

示例1:
输入:path = "/home/"
输出:"/home"
解释:注意,最后一个目录名后面没有斜杠。

示例2:
输入:path = "/../"
输出:"/"
解释:从根目录向上一级是不可行的,因为根目录是你可以到达的最高级。

示例3:
输入:path = "/home//foo/"
输出:"/home/foo"
解释:在规范路径中,多个连续斜杠需要用一个斜杠替换。

示例4:
输入:path = "/a/./b/../../c/"
输出:"/c"

AC代码:

class Solution:
    def simplifyPath(self, path: str) -> str:
        stack = []
        ans = []
        path = path+'/' # 因为给的路径可能最后没有/就会出错
        for i in range(1,len(path)):
            if path[i] == '/':
                s = ''.join(stack)
                stack.clear()
                if s == '..' :
                    if len(ans) > 0:
                        ans.pop()
                elif s == '.' or s == '':
                    pass
                else:
                    ans.append(s)
            else:
                stack.append(path[i])
        res = '/'.join(ans)
        res = '/' + res
        return res

解题思路

    这道题类似括号匹配的思想。每次遇到’/’,就需要弹栈,其他的字符就入栈。弹栈之后要判断当前的路径。如果是’…/’,那么就需要将保存答案的列表中删除最后一个元素。如果是’./‘ 或者是’’ 说明还是当前路径,否则就说明是新的目录名,将其保存到答案列表中。
需要注意的是:路径最后给的不一定会有’/’,例如这种情况:’/a/b/…’ 。所以需要手动的给最后加上一个’/’。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值