Pagini recente » Cod sursa (job #878155) | Cod sursa (job #2225908) | Cod sursa (job #433639) | Cod sursa (job #1638119) | Cod sursa (job #881744)
Cod sursa(job #881744)
#include <stdio.h>
#include <stdlib.h>
int solve0 (int v[], int val, int hi)
{
int lo, mid;
lo = 1;
while (lo <= hi)
{
mid = lo + (hi-lo)/2;
if (v[mid] <= val) lo = mid + 1;
else hi = mid - 1;
}
mid = lo + (hi-lo)/2;
if (v[mid] > val) mid--;
if (v[mid] == val) return mid;
return -1;
}
int solve1 (int v[], int val, int hi)
{
int lo, mid;
lo = 1;
while (lo <= hi)
{
mid = lo + (hi-lo)/2;
if (v[mid] <= val) lo = mid + 1;
else hi = mid - 1;
}
mid = lo + (hi-lo)/2;
if (v[mid] > val) mid--;
return mid;
}
int solve2 (int v[], int val, int hi)
{
int lo, mid;
lo = 1;
while (lo <= hi)
{
mid = lo + (hi-lo)/2;
if (v[mid] < val) lo = mid + 1;
else hi = mid - 1;
}
mid = lo + (hi-lo)/2;
if (v[mid] < val) mid++;
return mid;
}
int main()
{
FILE *f;
FILE *g;
f = fopen("cautbin.in","r");
g = fopen("cautbin.out","w");
int n,i;
int v[100010];
fscanf(f,"%d",&n);
for (i = 1; i <= n; i++)
fscanf(f,"%d", &v[i]);
int m,tip,val;
fscanf(f,"%d", &m);
while (m--)
{
fscanf(f,"%d %d", &tip, &val);
if (tip == 0)
fprintf(g,"%d\n", solve0(v, val, n));
if (tip == 1)
fprintf(g,"%d\n", solve1(v, val, n));
if (tip == 2)
fprintf(g,"%d\n", solve2(v, val, n));
}
close(f);
close(g);
return 0;
}