Cod sursa(job #1513344)

Utilizator Malan_AbeleMalan Abele Malan_Abele Data 29 octombrie 2015 13:18:11
Problema Numarare triunghiuri Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.02 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("nrtri.in");
ofstream out("nrtri.out");
int n,v[850],c[30100],u[850],k,nr,mj,a,b;
int caut_bin(int st, int dr)
{
    mj=st+(dr-st)/2;
    if(v[mj]>a+b)
        caut_bin(st,dr-1);
    else{
        nr++;
        if(mj==dr)
            return mj;
        else{
            if(v[mj+1]>a+b)
                return mj;
            else
                return caut_bin(mj+1,n);
        }
    }
}
int main()
{
    in>>n;
    for(int i=1;i<=n;i++)
    {
        in>>v[i];
        if(v[i]>k)
            k=v[i];
    }
    for (int i=1;i<=n;i++)
    {
        c[v[i]]=c[v[i]]+1;
    }
    for (int i=1;i<=k;i++)
    {
        c[i]=c[i]+c[i-1];
    }
    for (int i=1;i<=n;i++)
    {
        u[c[v[i]]-1]=v[i];
        c[v[i]]=c[v[i]]-1;
    }
    for(int i=0;i<n-2;i++)
    {
        a=u[i];
        for(int j=i+1;j<n-1;j++){
            b=u[j];
            caut_bin(i+2,n-1);
        }
    }
    out<<nr;
    return 0;
}