心如止水
Je n'ai pas le temps
posts - 400,comments - 130,trackbacks - 0
采用枚举。
首先,Ax+By=0必须表示直线,即A、B不能同时为0;另外,要注意到直线不能过输入中的2N个点;检测点在直线的哪一侧,只需要简单的线性规划的知识。
以下是我的代码:
#include<cstdio>
using namespace std;
const int kMaxn(57);

int main()
{
    
/*
    freopen("data.in","r",stdin);
    freopen("data.out","w",stdout);
    //
*/

    
int n;
    
while(scanf("%d",&n)==1 && n)
    {
        
int x[kMaxn<<1],y[kMaxn<<1];
        
for(int i=1;i<=(n<<1);i++)
            scanf(
"%d%d",&x[i],&y[i]);

        
bool found(false);
        
int a,b;
        
for(int i=-500;i<=500 && !found;i++)
            
for(int j=-500;j<=500 && !found;j++)
            {
                
if(i==0 && j==0)
                    
continue;
                
bool cannot(false);
                
for(int k=1;k<=(n<<1);k++)
                    
if(i*x[k]+j*y[k]==0)
                    {
                        cannot
=true;
                        
break;
                    }
                
if(cannot)
                    
continue;
                
int t(0);
                
for(int k=1;k<=(n<<1);k++)
                    
if(i*x[k]+j*y[k]<0)
                        t
++;
                
if(t==n)
                {
                    a
=i;
                    b
=j;
                    found
=true;
                }
            }

        printf(
"%d %d\n",a,b);
    }

    
return 0;
}
posted on 2011-04-18 00:39 lee1r 阅读(483) 评论(0)  编辑 收藏 引用 所属分类: 题目分类:数学/数论

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理