当前位置:网站首页>Leetcode71. 简化路径
Leetcode71. 简化路径
2022-08-01 17:55:00 【Java全栈研发大联盟】
题目传送地址: 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("/../")) {
// //不能盲目的说遇到..就进行处理。 因为...里也包含.. 而...是可以为一个文件夹的名字 任何其他格式的点(例如,'...')均被视为文件/目录名称。
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;
}
边栏推荐
- opencv基本的图像处理
- Solve the problem that MySQL cannot insert Chinese data
- 插入排序 优化插入排序
- 解决MySQL插入不了中文数据问题
- 我在启牛开户安全吗?谁能告诉我开不靠谱?
- 【报错】Uncaught (in promise) TypeError: Cannot read properties of undefined (reading ‘concat‘)
- AIOps智能运维的领跑者擎创科技正式入驻InfoQ 写作社区!
- QT_QThread线程
- 2022年MySQL最新面试题
- CodeTON Round 2 (Div. 1 + Div. 2, Rated, Prizes!) 题解
猜你喜欢
随机推荐
ROS2系列知识(5):【参数】如何管理?
基于BiGRU和GAN的数据生成方法
QT基础功能,信号、槽
加州大学|通过图抽象从不同的第三人称视频中进行逆强化学习
统信软件、龙芯中科等四家企业共同发布《数字办公安全创新方案》
QT_QDialog 对话框
【无标题】setInterval和setTimeout详解
SRM供应商管理系统如何助力口腔护理企业实现采购战略的转型升级
QT_事件类
B002 - 基于嵌入式的老人定位追踪监测仪
阿里云的域名和ip绑定
OpenCV installation, QT, VS configuration project settings
吴恩达机器学习课后习题——kmeans
M1芯片电脑安装cerebro
QT常用全局宏定义
数字化采购管理系统开发:精细化采购业务流程管理,赋能企业实现“阳光采购”
今年最火爆的词:商业分析,看这一篇就够了!
存储日报-数据湖架构权威指南(使用 Iceberg 和 MinIO)
QLineEdit学习与使用
QT_QThread thread