Cod sursa(job #948036)

Utilizator Mitza444Vidrean Mihai Mitza444 Data 9 mai 2013 11:35:19
Problema Hashuri Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.03 kb
#include<cstdio>
#include<vector>
using namespace std;
#define MOD 666013
vector <int> Hash[MOD];
int N;
inline vector<int>::iterator gaseste(int x){
    int poz=x%MOD;
    vector<int>::iterator it;
    for(it=Hash[poz].begin();it!=Hash[poz].end();it++)
        if(*it==x)
            return it;
    return Hash[poz].end();
}
int adauga(int x){
    int poz=x%MOD;
    if(gaseste(x)==Hash[poz].end())
        Hash[poz].push_back(x);
}
int sterge(int x){
    int poz=x%MOD;
    vector <int>::iterator it=gaseste(x);
    if(it!=Hash[poz].end())
        Hash[poz].erase(it);
}
int main(){
    int op,val,i;
    freopen("hashuri.in","r",stdin);
    freopen("hashuri.out","w",stdout);
    scanf("%d",&N);
    for(i=1;i<=N;++i){
        scanf("%d%d",&op,&val);
        if(op==1){
            adauga(val);
        }
        else if(op==2){
            sterge(val);
        }
        else
            printf("%d\n",gaseste(val) != Hash[val % MOD].end());
    }
    fclose(stdin);
    fclose(stdout);
    return 0;
}