Cod sursa(job #3165885)

Utilizator nicushor21Pirlog Marian Nicolae nicushor21 Data 7 noiembrie 2023 09:14:40
Problema Numarare triunghiuri Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.88 kb
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
int n,v[800],i,j,st,dr,mid,sol;
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;i++){
        for(j=i+1;j<n;j++){
            st=j; dr=n-1;
                while(st<=dr){
                    mid=(st+dr)/2;
                    if(v[mid]<=v[i]+v[j]&&v[i]<=v[mid]+v[j]&&v[j]<=v[i]+v[mid]&&mid!=i&&mid!=j){
                        sol++;
                        cout<<v[mid]<<" "<<v[i]<<" "<<v[j]<<'\n';
                        st=mid+1;
                    } else if(v[mid]<=v[i]+v[j]){
                        st=mid+1;
                    } else{
                        dr=mid-1;
                    }
                }
        }
    }
    fout<<sol;
    return 0;
}