Cod sursa(job #2038196)

Utilizator mihai.alphamihai craciun mihai.alpha Data 13 octombrie 2017 14:51:10
Problema Hashuri Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.39 kb
#include <cstdio>
#include <vector>
#include <algorithm>

FILE *fin, *fout;

#define mod 666013

struct Hash  {
    std::vector <int> h[mod];
    inline void insert(int x)  {
        int rest = x % mod;
        for(size_t i = 0;i < h[rest].size();i++)  {
            if(h[rest][i] == x)
                return;
        }
        h[rest].push_back(x);
    }
    inline void erase(int x)  {
        int rest = x % mod;
        for(size_t i = 0;i < h[rest].size();i++)  {
            if(h[rest][i] == x)  {
                std::swap(h[rest][i], h[rest][h[rest].size() - 1]);
                h[rest].pop_back();
                break;
            }
        }
    }
    inline bool find(int x)  {
        int rest = x % mod;
        for(size_t i = 0;i < h[rest].size();i++)  {
            if(h[rest][i] == x)  {
                return 1;
            }
        }
        return 0;
    }
};

Hash hh;

int main()  {
    fin = fopen("hashuri.in", "r");
    fout = fopen("hashuri.out", "w");
    int N;
    fscanf(fin, "%d", &N);
    for(int i = 1;i <= N;i++)  {
        int op, x;
        fscanf(fin, "%d%d", &op, &x);
        if(op == 1)  {
            hh.insert(x);
        }
        else if(op == 2)  {
            hh.erase(x);
        }
        else  {
            fprintf(fout, "%d\n", hh.find(x));
        }
    }
    fclose(fin);
    fclose(fout);
    return 0;
}