You are asked to design a file system that allows you to create new paths and associate them with different values.
The format of a path is one or more concatenated strings of the form: /
followed by one or more lowercase English letters. For example, "/leetcode"
and "/leetcode/problems"
are valid paths while an empty string ""
and "/"
are not.
Implement the FileSystem
class:
bool createPath(string path, int value)
Creates a newpath
and associates avalue
to it if possible and returnstrue
. Returnsfalse
if the path already exists or its parent path doesn't exist.int get(string path)
Returns the value associated withpath
or returns-1
if the path doesn't exist.
Example 1:
Input: ["FileSystem","createPath","get"] [[],["/a",1],["/a"]] Output: [null,true,1] Explanation: FileSystem fileSystem = new FileSystem(); fileSystem.createPath("/a", 1); // return true fileSystem.get("/a"); // return 1
Example 2:
Input: ["FileSystem","createPath","createPath","get","createPath","get"] [[],["/leet",1],["/leet/code",2],["/leet/code"],["/c/d",1],["/c"]] Output: [null,true,true,2,false,-1] Explanation: FileSystem fileSystem = new FileSystem(); fileSystem.createPath("/leet", 1); // return true fileSystem.createPath("/leet/code", 2); // return true fileSystem.get("/leet/code"); // return 2 fileSystem.createPath("/c/d", 1); // return false because the parent path "/c" doesn't exist. fileSystem.get("/c"); // return -1 because this path doesn't exist.
Constraints:
2 <= path.length <= 100
1 <= value <= 109
- Each
path
is valid and consists of lowercase English letters and'/'
. - At most
104
calls in total will be made tocreatePath
andget
.
class Trie:
def __init__(self):
self.children = {}
self.v = 0
def insert(self, w, v):
node = self
ps = w.split('/')
for p in ps[1:-1]:
if p not in node.children:
return False
node = node.children[p]
if ps[-1] in node.children:
return False
node.children[ps[-1]] = Trie()
node = node.children[ps[-1]]
node.v = v
return True
def search(self, w):
node = self
for p in w.split('/')[1:]:
if p not in node.children:
return -1
node = node.children[p]
return node.v or -1
class FileSystem:
def __init__(self):
self.trie = Trie()
def createPath(self, path: str, value: int) -> bool:
return self.trie.insert(path, value)
def get(self, path: str) -> int:
return self.trie.search(path)
# Your FileSystem object will be instantiated and called as such:
# obj = FileSystem()
# param_1 = obj.createPath(path,value)
# param_2 = obj.get(path)
class Trie {
Map<String, Trie> children = new HashMap<>();
int v;
boolean insert(String w, int v) {
Trie node = this;
String[] ps = w.split("/");
for (int i = 1; i < ps.length - 1; ++i) {
String p = ps[i];
if (!node.children.containsKey(p)) {
return false;
}
node = node.children.get(p);
}
if (node.children.containsKey(ps[ps.length - 1])) {
return false;
}
node.children.put(ps[ps.length - 1], new Trie());
node = node.children.get(ps[ps.length - 1]);
node.v = v;
return true;
}
int search(String w) {
Trie node = this;
String[] ps = w.split("/");
for (int i = 1; i < ps.length; ++i) {
String p = ps[i];
if (!node.children.containsKey(p)) {
return -1;
}
node = node.children.get(p);
}
return node.v == 0 ? -1 : node.v;
}
}
class FileSystem {
private Trie trie = new Trie();
public FileSystem() {
}
public boolean createPath(String path, int value) {
return trie.insert(path, value);
}
public int get(String path) {
return trie.search(path);
}
}
/**
* Your FileSystem object will be instantiated and called as such:
* FileSystem obj = new FileSystem();
* boolean param_1 = obj.createPath(path,value);
* int param_2 = obj.get(path);
*/
type Trie struct {
children map[string]*Trie
v int
}
func newTrie() *Trie {
m := map[string]*Trie{}
return &Trie{children: m}
}
func (this *Trie) insert(w string, v int) bool {
node := this
ps := strings.Split(w, "/")
for _, p := range ps[1 : len(ps)-1] {
if _, ok := node.children[p]; !ok {
return false
}
node, _ = node.children[p]
}
x := ps[len(ps)-1]
if _, ok := node.children[x]; ok {
return false
}
node.children[x] = newTrie()
node, _ = node.children[x]
node.v = v
return true
}
func (this *Trie) search(w string) int {
node := this
for _, p := range strings.Split(w, "/")[1:] {
if _, ok := node.children[p]; !ok {
return -1
}
node, _ = node.children[p]
}
if node.v == 0 {
return -1
}
return node.v
}
type FileSystem struct {
trie *Trie
}
func Constructor() FileSystem {
return FileSystem{newTrie()}
}
func (this *FileSystem) CreatePath(path string, value int) bool {
return this.trie.insert(path, value)
}
func (this *FileSystem) Get(path string) int {
return this.trie.search(path)
}
/**
* Your FileSystem object will be instantiated and called as such:
* obj := Constructor();
* param_1 := obj.CreatePath(path,value);
* param_2 := obj.Get(path);
*/