Pagini recente » Cod sursa (job #1470284) | Cod sursa (job #2096141) | Cod sursa (job #945741) | Cod sursa (job #680633) | Cod sursa (job #1216071)
#include<fstream>
#include<vector>
#define pb push_back
#define LL long long
#define MOD 666013
#define MAXN 666020
using namespace std;
ifstream cin("hashuri.in");
ofstream cout("hasuri.out");
LL N;
int op;
vector<LL> H[MAXN];
//find
vector<LL>::iterator find_value(LL int X){
vector<LL>::iterator it;
LL V=X%MOD;
it=H[V].begin();
while(it!=H[V].end() && *it!=X )
it++;
return it;
}
void add_value(LL X) {
if(find_value(X)==H[X%MOD].end())
H[X%MOD].pb(X);
}
void erase_value(LL X) {
if(find_value(X)!=H[X%MOD].end())
H[X%MOD].erase(find_value(X));
}
int main() {
LL i,X;
cin>>N;
for(i=1;i<=N;i++){
cin>>op>>X;
switch(op) {
case 1 : add_value(X); break;
case 2 : erase_value(X); break;
case 3 : if(find_value(X)==H[X%MOD].end()) cout<<"0 ";
else cout<<"1 "; break;
}
}
return 0;
}