以 Unix 风格给出一个文件的绝对路径,你需要简化它。或者换句话说,将其转换为规范路径。
在 Unix 风格的文件系统中,一个点(.)表示当前目录本身;此外,两个点 (…) 表示将目录切换到上一级(指向父目录);两者都可以是复杂相对路径的组成部分。更多信息请参阅:Linux / Unix中的绝对路径 vs 相对路径
请注意,返回的规范路径必须始终以斜杠 / 开头,并且两个目录名之间必须只有一个斜杠 /。最后一个目录名(如果存在)不能以 / 结尾。此外,规范路径必须是表示绝对路径的最短字符串。
示例 1:
输入:"/home/"
输出:"/home"
解释:注意,最后一个目录名后面没有斜杠。
示例 2:
输入:"/…/"
输出:"/"
解释:从根目录向上一级是不可行的,因为根是你可以到达的最高级。
示例 3:
输入:"/home//foo/"
输出:"/home/foo"
解释:在规范路径中,多个连续斜杠需要用一个斜杠替换。
示例 4:
输入:"/a/./b/…/…/c/"
输出:"/c"
示例 5:
输入:"/a/…/…/b/…/c//.//"
输出:"/c"
class Solution {
private:
void split(string path, string &sep, stack<string> &sta)
{
int start = 0, end = 0;
end = path.find(sep);
while(end != string::npos)
{
if(end != start) //此处添加判断,可去除首字符'/'的干扰,同时去除连续"//"的干扰
{
string strTemp = path.substr(start, end-start);
if(strTemp == ".")
{
}
else if(strTemp == "..")
{
if(!sta.empty())
{
sta.pop();
}
}
else
{
sta.push(strTemp);
}
}
start = end + sep.length();
end = path.find(sep, start);
}
if(start < path.length()) //结尾字符不为"/"的情况
{
string strTemp = path.substr(start, end-start);
if(strTemp == ".")
{
}
else if (strTemp == "..")
{
if(!sta.empty())
{
sta.pop();
}
}
else
{
sta.push(strTemp);
}
}
}
public:
string simplifyPath(string path) {
string sep = "/";
stack<string> sta;
split(path, sep, sta);
string strRes = "";
while(!sta.empty())
{
strRes = "/" + sta.top() + strRes;
sta.pop();
}
return (strRes == "" ? "/" : strRes);
}
};
利用栈的特征