Pagini recente » Cod sursa (job #493229) | Cod sursa (job #2399945) | Cod sursa (job #1634925) | Cod sursa (job #1260529) | Cod sursa (job #869667)
Cod sursa(job #869667)
#include<stdio.h>
int n,x,v[10000],m,k,tip;
int main()
{
FILE *f,*g;
f=fopen("cautbin.in","r");
g=fopen("cautbin.out","w");
fscanf(f,"%d",&n);
for (int i=1;i<=n;i++)
fscanf(f,"%d",&v[i]);
fscanf(f,"%d",&k);
for(int j=1;j<=k;j++)
{
fscanf(f,"%d %d",&tip,&x);
int st=0, dr=n+1;
if(tip==0)
{
while(st+1<dr)
{
m=(st+dr)/2;
if(x<v[m])
dr=m;
else
st=m;
}
if(v[st]==x)
fprintf(g,"%d\n",st);
else fprintf(g,"-1\n");
}
else
if(tip==1)
{
while(st+1<dr)
{
m=(st+dr)/2;
if(x>=v[m])
st=m;
else
dr=m;
}
fprintf(g,"%d\n",st);
}
else
if(tip==2)
{
while(st+1<dr)
{
m=(st+dr)/2;
if(x<=v[m])
dr=m;
else
st=m;
}
fprintf(g,"%d\n",dr);
}
}
fclose(f);
fclose(g);
return 0;
}