当前位置:   article > 正文

华为OD机试统一考试D卷C卷 - 模拟目录管理功能(C++ Java JavaScript Python)_模拟目录管理功能,用 python

模拟目录管理功能,用 python

华为OD机考:OD统一考试D卷+C卷+A卷+B卷+刷题OJ

真题目录:真题目录(D卷 + C卷 + B卷 + A卷) + 考点说明
必刷专栏:最新2024华为OD机试(Java/JS/Py/C/C++)+ OJ
在线OJ :点击立即刷题,模拟真实机考环境
华为OD面试真题精选:华为OD面试真题精选

题目描述

实现一个模拟目录管理功能的软件,输入一个命令序列,输出最后一条命令运行结果。

支持命令:

  • 创建目录命令:mkdir 目录名称,如 mkdir abc 为在当前目录创建abc目录,如果已存在同名目录则不执行任何操作。此命令无输出。
  • 进入目录命令:cd 目录名称,如 cd abc 为进入abc目录,特别地,cd … 为返回上级目录,如果目录不存在则不执行任何操作。此命令无输出。
  • 查看当前所在路径命令:pwd,输出当前路径字符串。

约束:

  • 目录名称仅支持小写字母;mkdir 和 cd 命令的参数仅支持单个目录,如:mkdir abc 和 cd abc;不支持嵌套路径和绝对路径,如 mkdir abc/efg,cd abc/efg,mkdir /abc/efg,cd /abc/efg 是不支持的。
  • 目录符号为/,根目录/作为初始目录。
  • 任何不符合上述定义的无效命令不做任何处理并且无输出。

输入描述

输入 N 行字符串,每一行字符串是一条命令。

命令行数限制100行以内,目录名称限制10个字符以内。

输出描述

输出最后一条命令运行结果字符串。

用例

输入

mkdir abc
cd abc
pwd
  • 1
  • 2
  • 3

输出

/abc/
  • 1

说明

在根目录创建一个abc的目录并进入abc目录中查看当前目录路径,输出当前路径/abc/。

解题思路

  1. 定义一个节点类(Node),用于表示文件系统中的每个目录。该类包含路径信息和一个映射,映射存储子目录和对应的节点对象。

  2. 创建一个根节点实例,代表文件系统的根目录。根目录没有父目录。

  3. 读取用户输入,根据输入的命令和参数执行相应的操作。

    • 如果输入的是创建目录的命令(例如,“mkdir”),检查目录名是否有效,然后在当前节点下创建新的子目录节点。
    • 如果输入的是切换目录的命令(例如,“cd”),检查目标目录是否存在,如果存在,
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/空白诗007/article/detail/910183
推荐阅读
相关标签
  

闽ICP备14008679号