Pagini recente » Cod sursa (job #2439694) | Cod sursa (job #2785476) | Cod sursa (job #1512725) | Cod sursa (job #3136592) | Cod sursa (job #332114)
Cod sursa(job #332114)
#include "fstream"
#include "math.h"
std::ifstream in("nrtri.in");
std::ofstream out("nrtri.out");
int poz1,poz2,i,j;
int cautareBinara(int vect[],int val1,int val2,int stanga,int dreapta)
{
int gasit=0;
while (stanga <= dreapta&&gasit<2) {
int mijloc = (stanga + dreapta) / 2;
if (vect[mijloc]<=val1+val2&&vect[mijloc+1]>val1+val2&&vect[mijloc]+val1>=val2&&vect[mijloc]+val2>=val1&&mijloc!=j&&mijloc!=i)
{poz1=mijloc;gasit++;}
else if (vect[mijloc] > val1+val2)
dreapta = mijloc - 1;
else
stanga = mijloc + 1;
if(vect[mijloc]<=val2+val1&&vect[mijloc]+val1>=val2&&vect[mijloc]+val2>=val1&&vect[mijloc-1]<val2+val1&&mijloc!=j&&mijloc!=i)
{poz2=mijloc;gasit++;}
else if (vect[mijloc] > val1+val2)
dreapta = mijloc - 1;
else
stanga = mijloc + 1;
}
if(gasit==2)
return 1;
else
return 0;
}
void qSort(int vect[], int stanga, int dreapta) {
int i = stanga, j = dreapta;
int tmp;
int pivot = vect[(stanga + dreapta) / 2];
while (i <= j) {
while (vect[i] < pivot)
i++;
while (vect[j] > pivot)
j--;
if (i <= j) {
tmp = vect[i];
vect[i] =vect[j];
vect[j] = tmp;
i++;
j--;
}
};
if (stanga < j)
qSort(vect, stanga, j);
if (i < dreapta)
qSort(vect, i, dreapta);
}
int main ()
{
int k=0,n;
in>>n;
int *a=new int[n];
for(i=0;i<n;i++)
in>>a[i];
qSort(a,0,n-1);
for(i=0;i<n-2;i++)
for(j=i+1;j<n-1;j++)
if(cautareBinara(a,a[i],a[j],j+1,n-1))
k+=poz1-poz2+1;
out<<k;
in.close ();
out.close ();
return 0;
}