-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathtrie.cpp
79 lines (59 loc) · 1.25 KB
/
trie.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include <iostream>
using namespace std;
const int COUNTS=52;
//trie node
struct TrieNode
{
struct TrieNode *children[COUNTS];
int Endofword;
};
//To make a new node
struct TrieNode *getNode()
{
struct TrieNode *parent = new TrieNode;
parent->Endofword = 0;
for (int i = 0; i < COUNTS; ++i)
{
parent->children[i]=NULL;
}
return parent;
}
//To inser a string
void insert(TrieNode *root, string word)
{
struct TrieNode *iterate = root;
for (int i = 0; i < word.length(); ++i)
{
int index= word[i]-'a';
if(!iterate->children[index])
iterate->children[index]=getNode();
iterate=iterate->children[index];
}
iterate->Endofword+=1;
}
//To return the no of occurences of string
int search(TrieNode *root, string word)
{
struct TrieNode *iterate = root;
for (int i = 0; i < word.length(); ++i)
{
int index=word[i]-'a';
if(!iterate->children[index])
return 0;
iterate=iterate->children[index];
}
return iterate->Endofword;
}
//driver function
int main()
{
string words[] = {"pqrs","pssr","psst","pqrt","pqrs"};
int noOfwords= sizeof(words)/sizeof(words[0]);
TrieNode *root=getNode();
for (int i = 0; i < noOfwords; ++i)
{
insert(root,words[i]);
}
cout<<"No. of occurences of pqrs is "<<search(root,"pqrs")<<endl;
return 0;
}