Pagini recente » Cod sursa (job #84551) | Cod sursa (job #3212977) | Cod sursa (job #1109223) | Cod sursa (job #1293990) | Cod sursa (job #1472306)
#include <iostream>
#include <stdio.h>
using namespace std;
int m, n, v[100005];
inline int bsearch0 (int x) {
int mid, l = 0, r = n+1;
while (r - l > 1) {
mid = (l + r) / 2;
if (x < v[mid]) {
r = mid;
} else {
l = mid;
}
}
if (v[mid-1] == x) {
return mid;
}
return -1;
}
inline int bsearch1 (int x) {
int l = 0, r = n+1;
while (r - l > 1) {
int mid = (l + r) / 2;
if (v[mid] > x) {
r = mid;
} else {
l = mid;
}
}
return l;
}
inline int bsearch2 (int x) {
int l = 0, r = n+1;
while (r - l > 1) {
int mid = (l + r) / 2;
if (x <= v[mid]) {
r = mid;
} else {
l = mid;
}
}
return r;
}
int main (void) {
freopen("cautbin.in", "r", stdin);
freopen("cautbin.out", "w", stdout);
scanf("%d", &n);
for (int i = 0; i < n; ++i) {
cin >> v[i];
}
scanf("%d", &m);
for (int i = 0; i < m; ++i) {
int x, c;
scanf("%d%d", &c, &x);
if (c == 0) {
printf("%d\n", bsearch0(x));
} else if (c == 1) {
printf("%d\n", bsearch1(x));
} else {
printf("%d\n", bsearch2(x));
}
}
return 0;
}