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

商业网站建设案例课程 下载北京网站优化平台

商业网站建设案例课程 下载,北京网站优化平台,网络建站 响应式网站,网站和做游戏文章目录 Tag题目来源题目解读解题思路方法一:字符串数组模拟栈 其他语言python3 写在最后 Tag 【栈】【字符串】 题目来源 71. 简化路径 题目解读 将 Unix 风格的绝对路径转化成更加简洁的规范路径。字符串中会出现 字母、数字、/、_、. 和 .. 这几种字符&#…

文章目录

  • Tag
  • 题目来源
  • 题目解读
  • 解题思路
    • 方法一:字符串数组模拟栈
  • 其他语言
    • python3
  • 写在最后

Tag

【栈】【字符串】


题目来源

71. 简化路径


题目解读

Unix 风格的绝对路径转化成更加简洁的规范路径。字符串中会出现 字母数字/_... 这几种字符,其中 . 表示当前目录本身,.. 表示将目录切换到上一级目录。

最后返回的 规范路径 必须满足以下几个要求:

  • 必须以斜杠 / 开头;
  • 两个目录名之间必须只有一个 /
  • 最后一个路径名之后不能以 / 结尾;
  • 需要将路径字符串中的 ... 转到对应的路径输出。

解题思路

方法一:字符串数组模拟栈

对于本题,表示绝对路径的字符串中的目录名或者目录操作(...)都位于 / 之间,因此我们可以先根据分隔符 / 来分割字符串,得到目录名和目录操作。对应的 C++ 代码如下:

vector<string> split(string& ss, char delim) {/** 以字符 delim 分割字符串 ss,字符串数组中可能会出现空字符串*/vector<string> res; string str;for (auto s : ss) {if (s == delim) {res.push_back(str);str = "";}else {str += s;}}res.push_back(str); // 防止 ss 最后一个字符不是分隔时丢掉最后一个字符串return res;
}

以上代码表示根据分隔符 delim 来分割字符串 ss,将分割后的字符串存放到数组中。

在绝对路径中可能会存在多个连续的 /,那么经过 split() 分割代码分割后的字符串数组中可能会出现空字符串,这一点需要注意,后续在遍历字符串数组时不需要处理空字符。

有了目录名和目录操作之后,我们就可以根据目录名和目录操作对目录进行操作生成简洁的规范路径了。因为在路径操作中会返回上一级目录,这里有一种 “先进后出” 的特性,所以使用 这种基本的数据结构来存储目录名(遇到 ..,我们就弹出当前的栈顶元素,新漏出来的字符串就是当前的目录)。简化路径之后,我们还需要将栈中的所有目录名使用 / 连接起来,这一步骤需要从栈底到栈顶的顺序遍历栈中目录,因此为了方便遍历操作,使用字符串数组模拟栈。

选定了基本的数据结构之后,我们就可以遍历字符串数组:

  • 如果当前的字符串为 ..,并且栈非空,那么我们就要弹出栈顶元素,模拟返回上一级目录;
  • 否则,如果当前的字符串非空,并且不为 .,那么就将当前的目录名加入栈中。

遍历结束后,我们将栈中目录使用 / 拼接得到简洁的规范路径 res

  • 如果栈为空,res = "/"
  • 否则,枚举栈中目录名 str,更新 res += "/" + str
  • 最后返回 res

实现代码

class Solution {
public:vector<string> split(string& ss, char delim) {/** 以字符 delim 分割字符串 ss,字符串数组中可能会出现空字符串*/vector<string> res; string str;for (auto s : ss) {if (s == delim) {res.push_back(str);str = "";}else {str += s;}}res.push_back(str); // 防止 ss 最后一个字符不是分隔时丢掉最后一个字符串return res;}string simplifyPath(string path) {vector<string> names = split(path, '/');vector<string> stk;for (string& name : names) {// 遇到 ".." 切换到上一级目录if (name == "..") {if (!stk.empty()) {stk.pop_back();}}// 遇到目录名加入栈else if (!name.empty() && name != ".") {stk.push_back(name);}}// 将栈中的目录以 '/' 作为分隔,包装起来string res;if (stk.empty()) {res = "/";}else {for (string& str : stk) {res += "/" + str;}}return res;}
};

复杂度分析

时间复杂度: O ( n ) O(n) O(n) n n n 是字符串 path 的长度。

空间复杂度: O ( n ) O(n) O(n),需要 O ( n ) O(n) O(n) 的空间存储 names 中的所有字符串。


其他语言

python3

class Solution:def simplifyPath(self, path: str) -> str:names = path.split("/")stack = list()for name in names:if name == "..":if stack:stack.pop()elif name and name != ".":stack.append(name)return "/" + "/".join(stack)

写在最后

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。

最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。

http://www.hkea.cn/news/16233/

相关文章:

  • 电子公司网站设计网站维护一般怎么做
  • 做网站图片怎么找新站网站推广公司
  • domain 网站建设app地推接单平台有哪些
  • wordpress网站实现微信登录企业网络推广
  • 高端网站设计欣赏郑州网站
  • 重庆网站设计公司推荐会计培训班
  • 可以用什么做网站登录页面怎样做引流推广
  • 河北网站seo外包搜索引擎优化的主题
  • 域名对网站的影响百度搜索风云榜排行榜
  • 电子商务b2c网站建设品牌策划书
  • 做网站怎么切片网络营销与直播电商专业
  • 如何赋予网站建设以生命力朋友圈推广
  • 做网站的公司深圳系统优化软件哪个好
  • 新余公司做网站qq代刷网站推广免费
  • 西安 网站建设 费用厉害的seo顾问
  • 移动营销关键词优化搜索引擎
  • 怎么让网站绑定域名访问不了搜索引擎营销的原理是什么
  • 济南网站惠州百度seo找谁
  • 自助餐火锅网站建设企业推广哪个平台好
  • b s网站系统如何做性能测试站外推广怎么做
  • wordpress搭建视频教程深圳最好的外贸seo培训
  • 游戏发卡中心网站源码抖音seo运营模式
  • 三里屯做网站的公司软件开发工资一般多少
  • 郑州做网站第一人湖北最新消息
  • 织梦网站地图怎么做sitemap.xml怎样制作网站
  • 可靠的合肥网站建设搜索推广
  • 网页源码怎么做网站整站seo服务
  • 做视频素材哪个网站好电商热门关键词
  • 电商建站价格南宁求介绍seo软件
  • 长沙网站制作的公司网站制作教程