Pagini recente » Cod sursa (job #2293672) | Cod sursa (job #274513) | Cod sursa (job #1754004) | Cod sursa (job #1464314) | Cod sursa (job #2640814)
#include <fstream>
#include <iostream>
using namespace std;
ifstream fin ("cautbin.in");
ofstream fout ("cautbin.out");
int n, v[100000];
int maxBinarySearch(int el) {
int left = 0, right = n - 1;
while (left < right) {
int middle = left + (right - left) / 2 + (right - left) % 2;
if (v[middle] <= el)
left = middle;
else
right = middle - 1;
}
return left;
}
int minBinarySearch(int el) {
int left = 0, right = n - 1;
while (left < right) {
int middle = left + (right - left) / 2;
if (v[middle] < el)
left = middle + 1;
else
right = middle;
}
return left;
}
int main() {
fin >> n;
for (int i = 0; i < n; i++)
fin >> v[i];
int m, type, el;
fin >> m;
for (int i = 0; i < m; i++) {
fin >> type >> el;
if (type < 2) {
int pos = maxBinarySearch(el);
if (!type && v[pos] != el)
fout << "-1\n";
else
fout << pos + 1<< "\n";
}
else
fout << minBinarySearch(el) + 1;
}
return 0;
}
/*
-> cea mai mare pozitie
int middle = left + (right - left) / 2 + (right - left) % 2;
if (v[middle] <= el)
left = middle;
else
right = middle - 1;
-> cea mai mica pozitie
int middle = left + (right - left) / 2;
if (v[middle] < el)
left = middle + 1;
else
right = middle;
*/