Given an absolute path for a file (Unix-style), simplify it.
For example,
path = "/home/"
, => "/home"
path = "/a/./b/../../c/"
, => "/c"
路径化简,.表示当前目录..表示上一级目录。
模拟一下,也可以用栈做。注意边界情况
Corner Cases:
- Did you consider the case where path =
"/../"
? In this case, you should return"/"
. - Another corner case is the path might contain multiple slashes
'/'
together, such as"/home//foo/"
. In this case, you should ignore redundant slashes and return"/home/foo"
.
class Solution {
public:
string simplifyPath(string path) {
string result,temp;
vector<string> s;
path ='/';
for(int i=0;i<path.size();i )
{
if(path[i]=='/')
{
if(temp=="" || temp==".")
{
}
else if(temp=="..")
{
if(!s.empty()) s.pop_back();
}
else
s.push_back(temp);
temp="";
}
else
temp =path[i];
}
if(!path.empty() && s.empty()) result ='/';
for(int i=0;i<s.size();i ) result ='/' s[i];
return result;
}
};