华为OD机考2025C卷 - 模拟目录管理功能 (Java & Python& JS & C++ & C )

最新华为上机考试

真题目录:点击查看目录
华为OD面试真题精选:点击立即查看
2025华为od机试2025C卷-华为OD上机考试2025年C卷

题目描述

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

支持命令:

  • 创建目录命令: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

输出

/abc/

说明

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

解题思路

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

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

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

    • 如果输入的是创建目录的命令(例如,“mkdir”),检查目录名是否有效,然后在当前节点下创建新的子目录节点。
    • 如果输入的是切换目录的命令(例如,“cd”),检查目标目录是否存在,如果存在,则更新当前节点为目标节点。
    • 如果输入的是打印当前目录路径的命令(例如,“pwd”),则输出当前节点的路径信息。
  4. 循环读取输入直到结束,并在结束时输出最后的路径信息。

C++

#include <iostream>
#include <string>
#include <unordered_map>
#include <sstream>

using namespace std;
// 定义一个类Node,用于表示文件系统中的每个目录
class Node {
   
   
public:
    string path; // 目录的路径
    unordered_map<string, Node*> next; // 存储当前目录下的子目录,键为目录名,值为对应的Node指针

    // Node类的构造方法
    Node(string path, Node* parent) : path(path) {
   
   
        // 如果存在父目录,则在子目录映射中添加一个指向父目录的条目
        if (parent != nullptr) {
   
   
            this->next[".."] = parent;
        }
    }
};

// 检查目录名是否有效的函数,目录名只能包含小写字母
bool isValidDirectoryName(const string& name) {
   
   
    for (char c : name) {
   
   
        if (c < 'a' || c > 'z') {
   
   
            return false; // 如果目录名中包含非小写字母的字符,则返回false
        }
    }
    return true; // 如果目录名全部由小写字母组成,则返回true
}

// 检查是否可以切换到指定的目录的函数,目录名要么是有效的,要么是".."表示上级目录
bool isValidChangeDirectory(const string& name) {
   
   
    return name == ".." || isValidDirectoryName(name); // 如果是".."或者是有效的目录名,则返回true
}

int main() {
   
   
    Node* root = new Node("/", nullptr); // 创建根目录节点,根目录没有父目录,所以第二个参数为nullptr
    Node* currentNode = root; // 初始化当前目录为根目录
    string lastOutput; // 用于存储最后输出的路径

    // 循环读取用户输入的命令
    string input;
    while (getline(cin, input)) {
   
   
        istringstream iss(input);
        string command, arg;
        iss >> command;

        if (command == "mkdir") {
   
   
            iss >> arg;
            if (isValidDirectoryName(arg)) {
   
   
                // 如果目录名有效并且不存在,则创建一个新的目录节点,并将其添加到当前目录的子目录映射中
                if (currentNode->next.find(arg) == currentNode->next.end()) {
   
   
                    currentNode->next[arg] = new Node(currentNode->path + arg + "/", currentNode);
                }
            }
        } else if (command == "cd") {
   
   
            iss >> arg;
            if (isValidChangeDirectory(arg)) {
   
   
                // 处理cd命令,用于改变当前目录
                auto it = currentNode->next.find(arg);
                if (it != currentNode->next.end()) {
   
   
                    currentNode = it->second; // 如果目录存在,则将当前目录切换为该目录
                }
            }
        } else if (command == "pwd") {
   
   
            // 处理pwd命令,用于打印当前目录的路径
            lastOutput = currentNode->path; // 将当前目录的路径保存到lastOutput变量中
        }
    }

    cout << lastOutput << endl; // 循环结束后,打印最后保存的路径

  

    return 0;
}

Java

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

public class Main {
   
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值