2019-12-19 17:37:30 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdbool.h>
|
2019-12-19 19:48:43 +08:00
|
|
|
|
2019-12-19 17:37:30 +08:00
|
|
|
#include <iostream>
|
2019-12-19 19:48:43 +08:00
|
|
|
#include <string>
|
2019-12-19 17:37:30 +08:00
|
|
|
|
|
|
|
// structure definition
|
|
|
|
typedef struct trie {
|
|
|
|
struct trie * arr[26];
|
|
|
|
bool isEndofWord;
|
2019-12-19 19:48:43 +08:00
|
|
|
} trie;
|
2019-12-19 17:37:30 +08:00
|
|
|
|
|
|
|
// create a new node for trie
|
|
|
|
trie * createNode() {
|
|
|
|
trie * nn = new trie();
|
|
|
|
for (int i = 0; i < 26; i++)
|
|
|
|
nn -> arr[i] = NULL;
|
|
|
|
nn -> isEndofWord = false;
|
|
|
|
return nn;
|
|
|
|
}
|
|
|
|
|
|
|
|
// insert string into the trie
|
2019-12-19 19:48:43 +08:00
|
|
|
void insert(trie * root, std::string str) {
|
|
|
|
for (int i = 0; i < str.length(); i++) {
|
2019-12-19 17:37:30 +08:00
|
|
|
int j = str[i] - 'a';
|
|
|
|
if (root -> arr[j]) {
|
|
|
|
root = root -> arr[j];
|
|
|
|
} else {
|
|
|
|
root -> arr[j] = createNode();
|
|
|
|
root = root -> arr[j];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
root -> isEndofWord = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// search a string exists inside the trie
|
2019-12-19 19:48:43 +08:00
|
|
|
bool search(trie * root, std::string str, int index) {
|
|
|
|
if (index == str.length()) {
|
2019-12-19 17:37:30 +08:00
|
|
|
if (!root -> isEndofWord)
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
int j = str[index] - 'a';
|
|
|
|
if (!root -> arr[j])
|
|
|
|
return false;
|
|
|
|
return search(root -> arr[j], str, index + 1);
|
|
|
|
}
|
|
|
|
|
2019-12-19 19:48:43 +08:00
|
|
|
/*
|
|
|
|
removes the string if it is not a prefix of any other
|
|
|
|
string, if it is then just sets the endofword to false, else
|
|
|
|
removes the given string
|
|
|
|
*/
|
|
|
|
bool deleteString(trie * root, std::string str, int index) {
|
|
|
|
if (index == str.length()) {
|
2019-12-19 17:37:30 +08:00
|
|
|
if (!root -> isEndofWord)
|
|
|
|
return false;
|
|
|
|
root -> isEndofWord = false;
|
|
|
|
for (int i = 0; i < 26; i++)
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
int j = str[index] - 'a';
|
|
|
|
if (!root -> arr[j])
|
|
|
|
return false;
|
|
|
|
bool
|
|
|
|
var = deleteString(root, str, index + 1);
|
|
|
|
if (var) {
|
|
|
|
root -> arr[j] = NULL;
|
|
|
|
if (root -> isEndofWord) {
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < 26; i++)
|
|
|
|
if (root -> arr[i])
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
trie * root = createNode();
|
2019-12-19 19:48:43 +08:00
|
|
|
insert(root, "hello");
|
|
|
|
insert(root, "world");
|
|
|
|
int a = search(root, "hello", 0);
|
|
|
|
int b = search(root, "word", 0);
|
2019-12-19 17:37:30 +08:00
|
|
|
printf("%d %d ", a, b);
|
|
|
|
return 0;
|
|
|
|
}
|