Pagini recente » Monitorul de evaluare | Cod sursa (job #1060052) | Cod sursa (job #270640) | Cod sursa (job #1688053) | Cod sursa (job #2238146)
#include <cstdio>
using namespace std;
int n, m, v[100005], quest, x, step, logN, poz;
int main()
{
FILE *in, *out;
in = freopen("cautbin.in", "r", stdin);
out = freopen("cautbin.out", "w", stdout);
scanf("%d", &n);
for (int i = 1; i <= n; ++i) scanf("%d", &v[i]);
scanf("%d", &m);
for (logN = 1; logN <= n; logN <<= 1);
for (int i = 1; i <= m; ++i) {
scanf("%d%d", &quest, &x);
if (quest < 2) {
for (step = logN, poz = 0; step; step >>= 1)
if (poz + step <= n && v[poz + step] <= x)
poz += step;
if (!quest && v[poz] != x) printf("-1\n");
else printf("%d\n", poz);
continue;
}
for (step = logN, poz = n; step; step >>=1)
if (poz - step >= 1 && v[poz - step] >= x)
poz -= step;
printf("%d\n", poz);
}
fclose(in);
fclose(out);
return 0;
}