Cod sursa(job #1233277)

Utilizator afkidStancioiu Nicu Razvan afkid Data 25 septembrie 2014 05:02:56
Problema Hashuri Scor 30
Compilator cpp Status done
Runda Arhiva educationala Marime 1.25 kb
#include <fstream>
#include <vector>

using namespace std;

const char Infile[]="hashuri.in";
const char OutFile[]="hashuri.out";
const int mod=666013;

ifstream in(Infile);
ofstream out(OutFile);

vector<int> hashtable[mod];
vector<int>::iterator it;

int n,i;

inline vector<int>::iterator Find(int x)
{
    int t=i%mod;
    for(it=hashtable[t].begin();it!=hashtable[t].end();++it)
        if(*it==x) return it;
    return hashtable[t].end();
}

inline void ins(int x)
{
    int t=i%mod;
    for(it=hashtable[t].begin();it!=hashtable[t].end();++it)
        if(*it==x) return;
    hashtable[t].push_back(x);
}

inline void ers(int x)
{
    int t=i%mod;
    for(it=hashtable[t].begin();it!=hashtable[t].end();++it)
    {
        if(*it==x)
        {
            hashtable[t].erase(it);
            return;
        }
    }
}

int main()
{
    int op;
    in>>n;
    while(in>>op>>i)
    {
        if(op==1)
            {
                ins(i);
                continue;
            }
        if(op==2)
        {
            ers(i);
            continue;
        }
        if(op==3 && Find(i)!=hashtable[i%mod].end())
            out<<"1"<<endl;
        else if(op==3) out<<"0"<<endl;

    }
    return 0;
}