Cod sursa(job #2073135)

Utilizator VladimirPopa123Vladimir Popa VladimirPopa123 Data 22 noiembrie 2017 18:58:36
Problema Numarare triunghiuri Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.73 kb
#include<fstream>
using namespace std;
ifstream fin("nrtri.in");
ofstream fout("nrtri.out");

int caut_1(int);
int n,v[801];

int main()
{
    int r = 0;
    fin>>n;
    for(int i=1; i<=n; i++) fin>>v[i];
    for(int i=1; i<n; i++)
        for(int j=i+1; j<=n; j++)
            if(v[i]>v[j])
            {
                int aux;
                aux=v[i];
                v[i]=v[j];
                v[j]=aux;
            }
    for(int i=1;i<n;i++)
        for(int j=i+1;j<=n;j++)
        {
            int k=caut_1(v[i]+v[j]);
            if(k>j) r+=k-j;
        }
    fout<<r;
    return 0;
}

int caut_1(int x)
{
    int pas,r=0;
    pas=1<<9;
    while(pas)
    {
        if(r+pas<=n&&v[r+pas]<=x) r+=pas;
        pas/=2;
    }
    return r;
}