Problem: 71. 简化路径
思路
复杂度
时间复杂度: O ( n ) O(n) O(n)
空间复杂度: O ( n ) O(n) O(n)
Code
Java
class Solution {
public String simplifyPath(String path)
{
ArrayDeque<String> d = new ArrayDeque<>();
int n = path.length();
// 从 1 开始 跳过第一个 / 根目录
for (int i = 1; i < n; i++)// i 表示 / 后面的第一个字母下标
{
if (path.charAt(i) == '/')// 重复的 / 直接跳过
continue;
int j = i + 1;// j 找到后面的 /
while (j < n && path.charAt(j) != '/')
j++;
String item = path.substring(i, j);// 取出文件名
if ("..".equals(item))// 回到上一级目录,即把上一个目录去掉
{
if (!d.isEmpty())
d.pollLast();
} else if (!".".equals(item))// . 则不作处理
{
d.addLast(item);// 其他的文件名直接加入栈中
}
i = j;
}
StringBuilder sb = new StringBuilder();
while (!d.isEmpty())
{
sb.append("/" + d.pollFirst());// 在每个 文件名/目录 前加上 "/"
}
return sb.length() == 0 ? "/" : sb.toString();// 特判只有根目录的情况
}
}