import scala.collection.mutable.{ArrayBuffer, Map} class TrieTree { private var root: TrieNode = new TrieNode() def insert(word: String) { var (text, node) = (word.trim, root) text.foreach( c => node = node.children.getOrElseUpdate(c, new TrieNode()) ) node.terminable = true node.count += 1 } def find(word: String): Boolean = { var node = root word.foreach ( c => { if (!node.children.contains(c)) return false node = node.children(c) }) node.terminable } def delete(word: String) { if (!find(word)) return deleteText(word, root) } private def deleteText(word: String, node: TrieNode): Boolean = { if (word.length == 0) { node.terminable = false return node.children.isEmpty } if (deleteText(word.substring(1), node.children(word.charAt(0).toChar))) { node.children -= word.charAt(0).toChar if (node.children.isEmpty && node.terminable == false) true } false } def traverse(): Unit = traverseTrie(root, new StringBuffer()) private def traverseTrie(node: TrieNode, word: StringBuffer) { if (node.terminable) { println(word + "------" + node.count) if (node.children.isEmpty) return } val children = node.children.keySet children foreach { c => traverseTrie(node.children(c), word.append(c)) word.deleteCharAt(word.length() - 1) } } class TrieNode { var terminable = false var count = 0 var children: Map[Char, TrieNode] = Map[Char, TrieNode]() } } object TrieTree { def main(args: Array[String]) { val trie = new TrieTree()
trie.insert("abcd") trie.insert("cd") trie.insert("abdr") trie.traverse() trie.delete("cd") println(" " + trie.find("cd")) } }