Pagini recente » Autentificare | Monitorul de evaluare | Profil M@2Te4i | Cod sursa (job #388545) | Cod sursa (job #2010764)
#include <bits/stdc++.h>
using namespace std;
int n,A[810],ans;
int caut(int a, int b){
int l=b+1,r=n,m,val=A[a]+A[b];
while (l<=r){
m=(l+r)/2;
if (val<A[m]) r=m-1;
else l=m+1;
}
return r-b;
}
int main(){
ifstream cin ("nrtri.in");
ofstream cout ("nrtri.out");
cin>>n;
for (int i=1; i<=n; i++) cin>>A[i];
sort(A+1,A+1+n);
for (int i=1; i<n-1; i++){
for (int j=i+1; j<n; j++) ans+=caut(i,j);
}
cout<<ans;
return 0;
}