Please can anyone provide a good implementation of trie using a 2D array instead of using recursion ?
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3814 |
3 | jqdai0815 | 3682 |
4 | Benq | 3529 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3517 |
7 | Radewoosh | 3410 |
8 | hos.lyric | 3399 |
9 | ecnerwala | 3392 |
9 | Um_nik | 3392 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | maomao90 | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 161 |
5 | djm03178 | 158 |
6 | -is-this-fft- | 157 |
7 | adamant | 155 |
8 | awoo | 154 |
8 | Dominater069 | 154 |
10 | luogu_official | 150 |
Please can anyone provide a good implementation of trie using a 2D array instead of using recursion ?
Name |
---|
let f be the matrix representation of your trie
let f[k] be the list of links for the k-th node
let f[k][x] = m, the node who represents the son of k-th node using x-th character, m = -1 is there is not a link.
Notes: Root node is at f[0] sz is the numbers of nodes currently in trie
I guess would be easy to you implement other functions.
It's my implementation of trie without using recursion and with using 2D array.
chrome Can you please explain your code. It would be really nice and helpful.
Thanks chrome!
You can find it in PrinceOfPersia's blog on data structures.
My code here
I like this because 'add' and 'query' are in the same function (:
Why is this used instead of making nodes by using struct?
1) because accessing values in arrays can benefit from caching while it won't be the case with struct since every node will be allocated wherever memory is available on heap(i.e. not contiguously).
2) Dynamically allocating memory on heap is slower(i.e. using
new
when using struct).There might be other reasons but the above are the only one's which i can think of now.