内容简介:【LeetCode】71. Simplify Path
问题描述
https://leetcode.com/problems/simplify-path/#/description
Given an absolute path for a file (Unix-style), simplify it.
For example
path = "/home/"
, => "/home"
path = "/a/./b/../../c/"
, => "/c"
Corner Cases:
- Did you consider the case where path = "/../"? In this case, you should return "/".
- Another corner case is the path might contain multiple slashes '/' together, such as "/home//foo/". In this case, you should ignore redundant slashes and return "/home/foo".
算法
使用 spli('/')
切割字符串,如 /a/./b/../../c/
切割为: ['a','.','b','..','.','c','']
,然后就好办了。使用一个栈来存储路径,然后遇到 ['.','']
就跳过去,遇到 '..'
就将栈的最近元素弹出。
代码
public String simplifyPath(String path) { Stack<String> stack = new Stack<>(); for(String dir:path.split("/")) { if("..".equals(dir)) { if(!stack.isEmpty()) stack.pop(); } else if(".".equals(dir)) { continue; } else { if(!"".equals(dir)) { stack.push(dir); } } } String r = ""; for(String dir:stack) { r = r + "/" + dir; } return "".equals(r)?"/":r; }转载请注明出处
:
http://www.zgljl2012.com/leetcode-71-simplify-path/
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据挖掘导论
Pang-Ning Tan, Michael Steinbach / 范明 范宏建 / 人民邮电出版社 / 2006-01-01 / 49.00元
本书全面介绍了数据挖掘的理论和方法,旨在为读者提供将数据挖掘应用于实际问题所必需的知识。本书涵盖五个主题:数据、分类、关联分析、聚类和异常检测。除异常检测外,每个主题都包含两章:前面一章讲述基本概念、代表性算法和评估技术,后面一章较深入地讨论高级概念和算法。目的是使读者在透彻地理解数据挖掘基础的同时,还能了解更多重要的高级主题。此外,书中还提供了大量示例、图表和习题。 本书适合作为......一起来看看 《数据挖掘导论》 这本书的介绍吧!