Cod sursa(job #2303584)

Utilizator Bogdy_PPrunescu Bogdan Bogdy_P Data 16 decembrie 2018 16:11:32
Problema Hashuri Scor 30
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.04 kb
#include <bits/stdc++.h>
#define MOD 9973
using namespace std;
ifstream in("hashuri.in");
ofstream out("hashuri.out");
vector <int> H[MOD + 2];
void Erase(int n)
{
    int k = n % MOD;
    vector <int>:: iterator it;
    for(it = H[k].begin();it != H[k].end(); )
    {
        if(*it == n)
        {
            H[k].erase(it);
            return ;
        }
    }
}
void Insert(int n)
{
    int k = n % MOD;
    vector <int>:: iterator it;
    for(it = H[k].begin();it != H[k].end(); )
    {
        if(*it == n) return ;
    }
    H[k].push_back(n);
}
bool Find(int n)
{
    int k = n % MOD;
    vector <int>:: iterator it;
    for(it = H[k].begin();it != H[k].end(); )
        if(*it == n) return 1;
    return 0;
}
int n, q, x;
int main()
{
    in >> n;
    for(int i = 1;i <= n;i++)
    {
        in >> q >> x;
        if(q == 1) Insert(x);
        if(q == 2) Erase(x);
        if(q == 3)
        {
            if(Find(x)) out << 1 << '\n';
            else out << 0 << '\n';
        }
    }
    return 0;
}