Cod sursa(job #3166068)

Utilizator nicushor21Pirlog Marian Nicolae nicushor21 Data 7 noiembrie 2023 17:17:14
Problema Numarare triunghiuri Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.72 kb
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
int n,v[800],i,j,st,dr,mid,sol=0,poz;
int main(){
    ifstream fin("nrtri.in");
    ofstream fout("nrtri.out");
    fin>>n;
    for(i=0;i<n;i++){
        fin>>v[i];
    }
    sort(v,v+n);
    for(i=0;i<n-2;i++){
        for(j=i+1;j<n-1;j++){
            st=j+1; dr=n-1; poz=j;
            while(st<=dr){
                mid=(st+dr)/2;
                if(v[mid]<=v[i]+v[j]){
                    st=mid+1;
                    poz=mid;
                } else{
                    dr=mid-1;
                }
            }
            sol+=poz-j;
        }
    }
    fout<<sol;
    fin.close();
    fout.close();
    return 0;
}