回复 4 楼 beyondyf
											能具体点吗? 这个程序运行出来是说能不能构成多边形,感觉与题意不符啊。
#include<iostream.h>
 const int N=4; 
 int tt(double p[][2],int a,int b)  
{  
int temp[N],k=0;double t; 
for(int i=0;i<N;i++) 
{if(i==a||i==b) 
{ continue;}  
t=p[i][0]*(p[b][1]-p[a][1])+(p[a][0]-p[b][0])*p[i][1]-p[a][0]*p[b][1]+p[b][0]*p[a][1]; 
if(t==0) return 0; 
 else  if(t>0) temp[k++]=1; 
 else  temp[k++]=-1;} 
for(int j=1;j<k;j++)  
{if(temp[0]!=temp[j]) return 0;} 
 return 1;} 
 int    real(double p[][2]) 
 { int flag[N],m=0; for(int i=0;i<N;i++){flag[i]=0;}
 for( i=0;i<N;i++) 
{
for(int j=1;j<N;j++) 
 {
if(flag[j]) continue;
if(tt(p,m,j)) 
{
 flag[m]=1; m=j;break; }
 }
} 
flag[m]=1; 
 for(i=0;i<N;i++)  
{
if(flag[i]==0) return 0;
}  
 if(tt(p,0,m)) return 1;
return 0;} 
void main() 
{double p[N][2]; 
char ch='y';   
while (ch=='y'||ch=='Y') 
 {cout<<"请输入点的坐标:"<<endl; 
for(int i=0;i<N;i++)  
{cout<<" 下一个点坐标:";cin>>p[i][0]>>p[i][1];cout<<p[i][0]<<","<<p[i][1]<<endl;}  
if (real(p))cout<<"能构成";else cout<<"不能构成";