<题目链接>
不会AC没关系;
实在不行回老家,
还有一亩三分地。
谢谢!(乐队奏乐)”
话说部分学生心态极好,每天就知道游戏,这次考试如此简单的题目,也是云里雾里,而且,还竟然来这么几句打油诗。
好呀,老师的责任就是帮你解决问题,既然想种田,那就分你一块。
这块田位于浙江省温州市苍南县灵溪镇林家铺子村,多边形形状的一块地,原本是linle 的,现在就准备送给你了。不过,任何事情都没有那么简单,你必须首先告诉我这块地到底有多少面积,如果回答正确才能真正得到这块地。
发愁了吧?就是要让你知道,种地也是需要AC知识的!以后还是好好练吧...
输入数据中所有的整数都在32位整数范围内,n=0表示数据的结束,不做处理。
每个实例的输出占一行。
#include <iostream> #include <algorithm> #include <cstring> #include <cstdio> #include <cmath> #include <stdlib.h> using namespace std; struct node { int x, y; node() {} node(int a, int b) :x(a), y(b) {} }; node arr[110]; double XMul(node a, node b) { //return fabs(a.x*b.y*1.0 - a.y*b.x*1.0)*0.5; 不能这样写,因为这个多边形可能是凹多边形 return (a.x*b.y*1.0 - a.y*b.x*1.0)*0.5; } double area(node a, node b) { //p1,p2分别为该三角形的两个向量边 node p1 = node(arr[1].x - a.x, arr[1].y - a.y); node p2 = node(arr[1].x - b.x, arr[1].y - b.y); return XMul(p1, p2); } int main() { int n; while (scanf("%d", &n) != EOF, n) { memset(arr, 0, sizeof(arr)); double sum = 0; for (int i = 1; i <= n; i++) { scanf("%d %d", &arr[i].x, &arr[i].y); } node last = arr[2]; for (int i = 3; i <= n; i++) { sum += area(last, arr[i]); last = arr[i]; } printf("%.1lf\n", fabs(sum)); //对sum取绝对值才是正解 } return 0; }