Cod sursa(job #2896460)

Utilizator AndreeaCreitaCreita Andreea AndreeaCreita Data 29 aprilie 2022 23:15:56
Problema Hashuri Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.41 kb
#include <bits/stdc++.h>

using namespace std;

#define NrHash 123431

vector<int> Hash[NrHash];

ifstream in("hashuri.in");
ofstream out("hashuri.out");


int cautare_in_hash (int x)
{
    int pozmodulo=x%NrHash;
    for(int i=0; i<Hash[pozmodulo].size(); i++)
        if(Hash[pozmodulo][i]==x)return 1;
    return 0;
}

int main()
{
    int n,operatie,nr,pozmodulo,ok,poz;
    in>>n;
    for(int i=1; i<=n; i++)
    {
        in>>operatie;
        in>>nr;
        if(operatie==1)
        {
            pozmodulo=nr%NrHash;
            if (cautare_in_hash(nr)==0)
                Hash[pozmodulo].push_back(nr);
        }
        if(operatie==2)
        {
            pozmodulo=nr%NrHash;
            int ok=0;
            for(int i=0; i<Hash[pozmodulo].size(); i++)
            {
                if(Hash[pozmodulo][i]==nr)
                {
                    ok=1;
                    poz=i;
                }
            }
            if(ok==1)
                Hash[pozmodulo].erase(Hash[pozmodulo].begin()+poz);
        }
        if(operatie==3)
        {
            int ok=0;
            pozmodulo=nr%NrHash;
            for(int i=0; i<Hash[pozmodulo].size(); i++)
                if(Hash[pozmodulo][i]==nr)
                {
                    ok=1;
                    out<<1<<'\n';
                }
            if(ok==0) out<<0<<'\n';
        }
    }
    return 0;
}