HDOJ 2036 改革春风吹满地题

/***** HDOJ 2036 改革春风吹满地题 ********/

/******** written by C_Shit_Hu ************/

/****************************************************************************/
/* 
  今日继续刷水题--杭电2036,改革春风吹满地

  多边形形状的一块地,你必须告诉我这块地到底有多少面积,如果回答正确才能真正得到这块地。
  输入数据包含多个测试实例,每个测试实例占一行,每行的开始是一个整数n(3<=n<=100),它表示多边形的边数(当然也是顶点数);
  然后是按照逆时针顺序给出的n个顶点的坐标(x1, y1, x2, y2... xn, yn),为了简化问题,这里的所有坐标都用整数表示。
  输入数据中所有的整数都在32位整数范围内,n=0表示数据的结束,不做处理。
  
  对于每个测试实例,请输出对应的多边形面积,结果精确到小数点后一位小数。
  每个实例的输出占一行。

*/
/****************************************************************************/

// 讨论区代码,如下。。。。
// 表示线代,学艺不精。。。呀。
// 多边形面积的求法公式,向量叉乘,分隔三角形

#include<stdio.h>
int main()
{
    int n,i,a[200],b[200];
    double sum;

    while(scanf("%d",&n),n) {
        for(i=0;i<n;i++)
            scanf("%d%d",&a[i],&b[i]);

        a[n]=a[0];b[n]=b[0];
        sum=0;
        for(i=1;i<=n;i++)
            sum+=a[i-1]*b[i]-a[i]*b[i-1];

        printf("%1.1f\n",sum/2);
    }
    return 0;
}

/********** 心得体会 ****************/
/*
    对这道题,我只能说,好好学习数学。。。
    阶乘,以及矩阵。。。

    水水更健康 !!!

*/

/**************** The End ***********/

 

posted @ 2013-09-08 13:04  SuooL  阅读(302)  评论(0编辑  收藏  举报