/***** 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 ***********/