当前位置: 首页 > news >正文

leetcode71.简化路径

 参考了leetcode的官方题解,用/分割字符串就能解决多个/的问题,利用栈后进先出,碰到..就回退出栈,空字符串和.不用处理,其余正常的目录就入栈,最后双端链表从头拼接就是结果

class Solution {public String simplifyPath(String path) {Deque<String> deque = new LinkedList<>();String[] split = path.split("/");//1.向双端链表中放入符合要求的目录for (String s : split) {//1.1如果目录是..那么就要回到上级目录也就是出栈if (s.equals("..")) {if (!deque.isEmpty()) {deque.pollLast();}} else if (s.length() > 0 && !s.equals(".")) {//1.2如果是正常的目录就放入栈deque.addLast(s);}}//2.将双端链表从后向前拼接就是结果//2.1双端链表为空那么就是根目录if (deque.isEmpty()) {return "/";}//2.2双端链表不为空则拼接成完整路径StringBuilder stringBuilder = new StringBuilder();for (String s : deque) {stringBuilder.append("/").append(s);}return stringBuilder.toString();}
}

 

http://www.dtcms.com/a/268184.html

相关文章:

  • WPF学习笔记(26)CommunityToolkit.Mvvm与MaterialDesignThemes
  • 如何正确规范的开发术语自己的TYPECHO插件
  • AI做美观PPT:3步流程+工具测评+避坑指南
  • LeetCode 算法题解:链表与二叉树相关问题 打打卡
  • ubuntu 20.04 安装中文输入法 (sougou pin yin)
  • std::forward作用
  • day53
  • 微服务负载均衡全解析:从原理到实践
  • 【Note】《Kafka: The Definitive Guide》第三章: Kafka 生产者深入解析:如何高效写入 Kafka 消息队列
  • HarmonyOS学习6 --- 数据存储
  • windows系统安装mongoDB且创建集合植入初始化数据
  • vue事件处理-按键修饰符
  • 闲庭信步使用图像验证平台加速FPGA的开发:第一课——由测试平台到验证平台
  • CSS06:字体样式
  • 数据结构---链表结构体、指针深入理解(三)
  • Petalinux工程如何离线编译
  • C++ 中左值和右值
  • 论文评价指标之(n-gram、BLEU、MRR、ANLS)
  • python库 maya 库的各种案例的使用详解(人性化的日期时间处理)
  • 使用Python将PDF转换成word、PPT
  • SSL 终结(SSL Termination)深度解析:从原理到实践的全维度指南
  • 电商系统二次开发找谁做?ZKmall开源商城前后端分离技术更易升级迭代
  • leetcode 每日一题 1865. 找出和为指定值的下标对
  • python学习打卡:DAY 21 常见的降维算法
  • 红宝书学习笔记
  • 多级缓存如何应用
  • YOLO目标检测数据集类别:分类与应用
  • Oracle使用SQL一次性向表中插入多行数据
  • NLP之文本纠错开源大模型:兼看语音大模型总结
  • 李宏毅genai笔记:推理