#include <stdio.h> int main() { int N,i,j,k=0; double a[200][200]={0}; int c[200][200]={0}, C=-1; int b[2][200]={0}; scanf("%d",&N); for(i=0;i<N;i++){ scanf("%d %d",&b[0][i],&b[1][i]); } for(i=0;i<N;i++){ //기울기를 구해 a에 넣는다 for(j=i+1;j<N;j++){ //a에 있는 기울기들은 i마다 최대 점의수 -1 까지 들어가겠지 if(b[0][i]==b[0][j]) {C++; continue;} a[i][j]=(b[1][i]-b[1][j])/(b[0][i]-b[0][j]); } for(j=i+1;j<N-1;j++){ //갯수 세기 for(k=0;k<N-1;k++){ //if(a[i][j]!=0){ if(a[i][j]==a[i][k+1]) c[i][j]++; //} } } c[i][0]=c[i][j-1]; for(j=i+1;j<N-1;j++){ if(c[i][0]<c[i][j+1]) c[i][0]=c[i][j+1]; } } //입력해서 기울기를 a에 넣고, C에다 갯수 넣는다. if(C<c[0][0]) C=c[0][0]; for(i=0;i<N-1;i++){ if(c[i][0]<c[i+1][0]) C=c[i+1][0]; } if(C==0) C++; printf("%d",C+1); return 0; }