Pagini recente » Istoria paginii runda/daupentrumata/clasament | Cod sursa (job #234143) | Istoria paginii runda/oji_training_0/clasament | Cod sursa (job #2395926) | Cod sursa (job #912600)
Cod sursa(job #912600)
#include<cstdio>
#include<algorithm>
#include<vector>
#define mod 11111113
using namespace std;
vector<int>HASH[mod];
int n,i,j,k,x;
void add(int a,int b)
{
for (j=0;j<HASH[a].size();j++) if (HASH[a][j]==b) return;
HASH[a].push_back(b);
}
void erase(int a,int b)
{
for (j=0;j<HASH[a].size();j++) if (HASH[a][j]==b)
{
HASH[a][j]=-1;
return;
}
}
int calc(int a,int b)
{
for (j=0;j<HASH[a].size();j++) if (HASH[a][j]==b) return 1;
return 0;
}
int main()
{
freopen("hashuri.in","r",stdin);
freopen("hashuri.out","w",stdout);
scanf("%d",&n);
for (i=1;i<=n;i++)
{
scanf("%d %d",&k,&x);
if (k==1) add(x%mod,x);else
if (k==2) erase(x%mod,x);else
if (k==3) printf("%d\n",calc(x%mod,x));
}
return 0;
}