想要精通算法和SQL的成长之路 - 简化路径

想要精通算法和SQL的成长之路 - 简化路径

  • 前言
  • [一. 简化路径](#一. 简化路径)

前言

想要精通算法和SQL的成长之路 - 系列导航

一. 简化路径

原题连接

思路如下:

  1. 我们根据 "/" 去拆分字符串,得到每个子目录。这里拿到的子目录可能是空字符串,需要注意一下。
  2. 我们遍历这个目录,用一个双向队列存储合法的子目录。
  3. 如果遇到的子目录是 ". ." ,说明是向上层目录前进,我们从移除队尾元素。
  4. 如果遇到的子目录是 ".",咱啥也不用管。
  5. 剩余的子目录都是有效路径,我们往队尾塞。
  6. 最后我们再次遍历双向队列,从队首开始取,拼接字符串得到最终的简化路径。
java 复制代码
public String simplifyPath(String path) {
    LinkedList<String> queue = new LinkedList<>();
    for (String item : path.split("/")) {
        if (item.equals("..")) {
            // 队列必须非空,我们才能移除
            if (!queue.isEmpty()) {
                queue.pollLast();
            }
        } else if (!".".equals(item) && !item.isEmpty()) {// 这里注意一下,空元素以及 "." 我们都不用管
            queue.addLast(item);
        }
    }
    StringBuilder res = new StringBuilder();
    // 从队首元素开始取元素,拼接字符
    while (!queue.isEmpty()) {
        res.append("/" + queue.pollFirst());
    }
    String rr = res.toString();
    // 最后再判空一下
    return rr.isEmpty() ? "/" : rr;
}
相关推荐
Kethy__4 分钟前
计算机中级-数据库系统工程师-数据结构-树与二叉树(1)
数据结构·算法··数据库系统工程师·计算机中级
m0_651593916 分钟前
构建智能SKU系统:编码规则、元数据设计与DDD实战指南
java·大数据·数据库
乐之者v8 分钟前
统计数据时,sql执行超时,如何处理
服务器·数据库·sql
胖头鱼的鱼缸(尹海文)8 分钟前
数据库管理-第418期 从想法落地工程:Oracle DB构建AI Agent三位一体记忆体(20260403)
数据库·人工智能·oracle
电商API&Tina8 分钟前
【京东item_getAPI 】高稳定:API 、非爬虫、不封号、不掉线、大促稳跑
大数据·网络·人工智能·爬虫·python·sql·json
不愿透露姓名的大鹏9 分钟前
Oracle alert与trace日志清理全攻略(附实操命令)
linux·服务器·数据库·oracle
环黄金线HHJX.10 分钟前
BaClaw龙虾打字
开发语言·人工智能·算法·编辑器
AI科技星18 分钟前
光速螺旋量子几何统一场论:基于四维类时螺旋的物理现象统一推导
开发语言·线性代数·算法·数学建模·平面
xxjj998a18 分钟前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
无极低码18 分钟前
Oracle 常用运维SQL整理,改字段类型改表名创建基础用户授权等
数据库·sql·oracle