Pagini recente » Cod sursa (job #3271262) | Cod sursa (job #2770965) | Cod sursa (job #2500099) | Cod sursa (job #905159) | Cod sursa (job #996373)
Cod sursa(job #996373)
#include<iostream>
#include<fstream>
#define Nmax 1000
using namespace std;
int main()
{
ifstream f("trapez.in");
ofstream g("trapez.out");
int N,nr=0,n=1,trapez=0,unu=0,doi=0;
float panta[Nmax],V[Nmax][2];
f>>N;
for(int i=0;i<N;i++)
{
f>>V[i][0];
f>>V[i][1];
}
for(int i=0;i<N;i++)
for(int j=i+1;j<N;j++)
if(V[i][1]-V[j][1]==0) unu++;
else if (V[i][0]-V[j][0]==0) doi++;
else panta[nr++]=(V[i][1]-V[j][1])/(V[i][0]-V[j][0]);
for(int i=0;i<nr;i++)
for(int j=i+1;j<nr;j++)
if (panta[i]>panta[j]) {panta[i]=panta[i]-panta[j];
panta[j]=panta[j]+panta[i];
panta[i]=panta[j]-panta[i];}
for(int i=0;i<nr-1;i++)
if (panta[i]==panta[i+1]) n++;
else {trapez=trapez+n*(n-1)/2;
n=1;}
trapez=trapez+unu*(unu-1)/2;
trapez=trapez+doi*(doi-1)/2;
g<<trapez;
f.close();
g.close();
return 0;
}