力扣第71题:简化路径 放弃栈模拟,选择数据流√(C++)

目录

题目

思路

解题过程

复杂度

Code 


题目

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

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

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

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

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

示例 1:

输入:path = "/home//foo/"

输出:"/home/foo"

示例 2:

输入:path = "/home/user/Documents/../Pictures"

输出:"/home/user/Pictures"

示例 3:

输入:path = "/../"

输出:"/"

思路

流(istream)是C++提供的用于数据输入的类。
istringstream则是字符串输入流,它接收一个string文本用于初始化,我们随后可以将其中的内容以自定义方式读出。

以下Code: 

getline(iss,buffer,'/')

可以以'/'为分隔符将iss输入流的数据读入buffer缓存中。
当iss读完时,这个函数返回EOF(end of file),可以用于结束循环。
分割符'/'不会被写入buffer,但会被函数从iss中取出。

解题过程

构建循环体将字符串以'/'为分割依次读入答案。

构建字符串输入流istringstream iss(path);
定义string ans="/",buffer;
buffer以'/'为分割符读取iss中的数据:

读入空字符串("//"会将空字符写入buffer)直接跳过
读入"."直接跳过
读入".."回删ans
其余情况将buffer+'/'压入ans末尾。

注意字符串长度为1时保留一个'/'字符。

复杂度

时间复杂度: O(n)

空间复杂度: O(n)

 力扣第71题:简化路径 放弃栈模拟,选择数据流√(C++)_第1张图片

Code 

class Solution {
public:
    string simplifyPath(string path) {
        istringstream iss(path);
        string ans="/",buffer;
        while(getline(iss,buffer,'/')){
            if(!buffer.empty()&&buffer!="."&&buffer!="..")ans.append(buffer+'/');
            if(buffer==".."){
                if(ans.size()>1)ans.pop_back();
                while(ans.size()>1&&ans.back()!='/')ans.pop_back();
            }
        }
        if(ans.size()>1)ans.pop_back();
        return ans;
    }
};

你可能感兴趣的:(leetCode耐刷王,c++,开发语言)