-
Notifications
You must be signed in to change notification settings - Fork 0
/
phonelst.cpp
105 lines (100 loc) · 2.42 KB
/
phonelst.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// TRIE implementation....
// just take a variable to mark the end of the number...
// now while adding a number ...if you encounter an end...then "NO"
// and while adding a number if there are more nodes even ehen the node's end is reached then also answer is "NO"
#include<bits/stdc++.h>
#include <iostream>
using namespace std;
struct maka
{
maka* arr[10];
int end;
};
maka* create()
{
maka *temp;
temp=new maka();
for(int i=0;i<10;i++)
{
temp->arr[i]=NULL;
}
temp->end=0;
return temp;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int n,i,j;
int t,q;
int flag;
cin>>n;
while(n--)
{
flag=0;
string str;
int ln;
cin>>t;
vector< maka *> v;
maka *head;
head=create();
v.push_back(head);
while(t--)
{
maka *tempp;
cin>>str;
tempp=head;
ln=str.length();
if(flag==0)
{
for(i=0;i<ln-1;i++)
{
if(tempp->arr[str[i]-'0']==NULL)
{
tempp->arr[str[i]-'0']=create();
v.push_back(tempp->arr[str[i]-'0']);
}
if(tempp->end==1)
{
//cout<<"yo1\n";
flag=1;
}
tempp=tempp->arr[str[i]-'0'];
}
if(tempp->arr[str[i]-'0']!=NULL )
{
if(tempp->arr[str[i]-'0']->end!=1)
{
flag=1;
//cout<<"yo2\n";
}
}
else
{
if(tempp->end==1)
{
//cout<<"yo3\n";
flag=1;
}
tempp->arr[str[i]-'0']=create();
v.push_back(tempp->arr[str[i]-'0']);
tempp=tempp->arr[str[i]-'0'];
tempp->end=1;
}
}
}
//cout<<v.size();
for(i=0;i<v.size();i++)
{
delete v[i];
}
if(flag==0)
{
cout<<"YES\n";
}
else
{
cout<<"NO\n";
}
}
return 0;
}