Pagini recente » Cod sursa (job #3222555) | Cod sursa (job #1577001) | Cod sursa (job #2374361) | Cod sursa (job #557404) | Cod sursa (job #3036365)
#include <fstream>
using namespace std;
const int N = 1e6;
const int K = 666019;
struct element
{
int val, urm;
};
element v[N+1];
int lst[K], n_e;
int caut_poz(int val)
{
int c = val % K;
for (int p = lst[c]; p != 0; p = v[p].urm)
{
if (v[p].val == val)
{
return p;
}
}
return 0;
}
void adauga(int val)
{
if (caut_poz(val) != 0)
{
return;
}
int c = val % K;
n_e++;
v[n_e].val = val;
v[n_e].urm = lst[c];
lst[c] = n_e;
}
void sterge(int val)
{
int p = caut_poz(val);
if (p == 0)
{
return;
}
int c = val % K;
v[p].val = v[lst[c]].val;
lst[c] = v[lst[c]].urm;
}
int caut_bool(int val)
{
return (caut_poz(val) != 0);
}
int main()
{
ifstream in("hashuri.in");
ofstream out("hashuri.out");
int n;
in >> n;
for (int i = 0; i < n; i++)
{
int tip, val;
in >> tip >> val;
if (tip == 1)
{
adauga(val);
}
else if (tip == 2)
{
sterge(val);
}
else
{
out << caut_bool(val) << "\n";
}
}
in.close();
out.close();
return 0;
}