#include <iostream>
#include<cmath>
using namespace std;
int main(int argc, char** argv) {
int time;
cin>>time;
for(int i=0;i<time;i++){
int n,flag=0;
cin>>n;
double a[n][2];
for(int j=0;j<n;j++)
cin>>a[j][0]>>a[j][1];
if(n<=2) flag=0;
else
for(int p=0;p<n-2;p++)
for(int q=p+1;q<n-1;q++)
for(int j=q+1;j<n;j++)
if(fabs(((a[p][1]-a[q][1])/(a[p][0]-a[q][0]))-((a[j][1]-a[p][1])/(a[j][0]-a[p][0])))<= 1e-15) --(1)
{ flag=1;
goto test;}
test:cout<<(flag==1?"Yes":"No")<<endl;
}
}
这个提交后显示答案错误 把(1)的式子改成a[q][0]*a[j][1]-a[j][0]*a[q][1]+a[j][0]*a[p][1]-a[p][0]*a[j][1]+a[p][0]*a[q][1]-a[q][0]*a[p][1] 其他完全不变 就可以通过 也就是说用斜率判断不行 但是用坐标相乘判断就可以 为什么呀?