588 Design In-Memory File System
Last updated
Was this helpful?
Last updated
Was this helpful?
Design an in-memory file system to simulate the following functions:
ls
: Given a path in string format. If it is a file path, return a list that only contains this file's name. If it is a directory path, return the list of file and directory names in this directory. Your output (file and directory names together) should in lexicographic order.
mkdir
: Given a directory paththat does not exist, you should make a new directory according to the path. If the middle directories in the path don't exist either, you should create them as well. This function has void return type.
addContentToFile
: Given a file pathandfile contentin string format. If the file doesn't exist, you need to create that file containing given content. If the file already exists, you need to append given content to original content. This function has void return type.
readContentFromFile
: Given a file path, return itscontentin string format.
Example:
Note:
You can assume all file or directory paths are absolute paths which begin with/
and do not end with/
except that the path is just"/"
.
You can assume that all operations will be passed valid parameters and users will not attempt to retrieve file content or list a directory or file that does not exist.
You can assume that all directory names and file names only contain lower-case letters, and same names won't exist in the same directory.
(1) Trie
思路: 类似于建一个trie数,每个node代表file system的node,type 1代表是文件, type 0代表是目录。无论是call哪个command,我们都从trieNode的root根据输入的path遍历到相应的trieNode(traverse()函数的作用),然后再根据具体的command做出对应的操作
时间复杂度:O(n), n是输入路径的文件个数,ls, mkdir, addContentToFile和readContentFromFile都一样,空间复杂度O(n)