当前位置:网站首页>Leetcode71. Simplified Paths
Leetcode71. Simplified Paths
2022-08-01 17:59:00 【Java Full Stack R&D Alliance】
题目传送地址: https://leetcode.cn/problems/simplify-path/
运行效率
代码如下
public static String simplifyPath(String path) {
//因为一个.表示当前目录本身,所以可以直接忽略
while (path.contains("/./")) {
path = path.replace("/./", "/");
}
// '//'都被视为单个斜杠 '/' 任意多个连续的斜杠(即,'//')都被视为单个斜杠 '/'
while (path.contains("//")) {
path = path.replace("//", "/");
}
if (path.endsWith("/.") && path.length() > 2) {
// 因为要考虑到 path= /.
path = path.substring(0, path.length() - 2);
}
//此外,两个点 (..) 表示将目录切换到上一级(指向父目录)
while (path.contains("/../")) {
// //Can't say blindly..就进行处理. 因为...里也包含.. 而...Can be the name of a folder 任何其他格式的点(例如,'...')均被视为文件/目录名称.
StringBuilder stringBuilder = new StringBuilder(path);
int indexOf = path.indexOf("/../");
int lastIndexOf = path.lastIndexOf("/", indexOf - 1);
if (lastIndexOf != -1) {
stringBuilder.delete(lastIndexOf, indexOf + 3);
} else {
stringBuilder.delete(indexOf, indexOf + 3);
}
path = stringBuilder.toString();
}
if ("/".equals(path)) {
return "/";
}
if (path.endsWith("/")) {
path = path.substring(0, path.length() - 1);
}
if (path.endsWith("/..") && path.length() > 3) {
// 因为要考虑到 path= /..
int i = path.lastIndexOf("/", path.length() - 4);
path = path.substring(0, i);
if ("".equals(path)) {
return "/";
}
}
if (path.endsWith("...")) {
return path;
}
if ("/..".equals(path)) {
return "/";
}
if (path.endsWith(".")) {
path = path.substring(0, path.length() - 1);
}
return path;
}
边栏推荐
猜你喜欢

B002 - Embedded Elderly Positioning Tracking Monitor

Xingtu has been short of disruptive products?Will this M38T from the Qingdao factory be a breakthrough?

【报错】Uncaught (in promise) TypeError: Cannot read properties of undefined (reading ‘concat‘)

关于Mysql服务无法启动的问题

Leetcode72. 编辑距离
![[供应链·案例篇]石油和天然气行业的数字化转型用例](/img/44/9ef9f86f8afb85f49aac1cce55723d.jpg)
[供应链·案例篇]石油和天然气行业的数字化转型用例

吴恩达机器学习课后习题——kmeans

【Day_10 0428】井字棋

分布式消息队列平滑迁移技术实战

B011 - 基于51的多功能指纹智能锁
随机推荐
typora操作手册
千万级乘客排队系统重构&压测方案总结篇
统信软件、龙芯中科等四家企业共同发布《数字办公安全创新方案》
C语言理论--笔试面试基础稳固
opencv real-time face detection
【Day_09 0427】 另类加法
OnePlus 10RT appears on Geekbench, product launch also seems to be approaching
RecSys'22|CARCA:交叉注意力感知上下文和属性进行推荐
RecSys'22|CARCA: Cross-Attention-Aware Context and Attribute Recommendations
深入分析类加载器
【Day_11 0506】 最近公共祖先
机器学习快速入门
sql添加索引
面经汇总-社招-6年
关于单应性矩阵的若干思考
Leetcode75. 颜色分类
快速抽取resnet_v2_152中间的特征层
使用设备树时对应的驱动编程
以消费场景为驱动的CMDB要怎么建?
我在启牛开户安全吗?谁能告诉我开不靠谱?