求面积 (坐标叉积公式+凹多边形面积-坐标公式)
来源:互联网 发布:知豆电动汽车 电话 编辑:程序博客网 时间:2024/05/18 17:05
求面积(AREA)
给出一个简单多边形(没有缺口),它的边要么是垂直的,要么是水平的。要求计算多边形的面积。
多边形被放置在一个X-Y的卡笛尔平面上,它所有的边都平行于两条坐标轴之一。然后按逆时针方向给出各顶点的坐标值。所有的坐标值都是整数(因此多边形的面积也为整数)。
输入
输入文件第一行给出多边形的顶点数n(n≤100)。接下来的几行每行给出多边形一个顶点的坐标值X和Y(都为整数并且用空格隔开)。顶点按逆时针方向逐个给出。并且多边形的每一个顶点的坐标值-200≤x,y≤200。多边形最后是靠从最后一个顶点到第一个顶点画一条边来封闭的。
输出
输出文件仅有一行包含一个整数,表示多边形的面积。
样例
AREA.IN
10
0 0
4 0
4 1
3 1
3 3
2 3
2 2
1 2
1 3
0 3
AREA.OUT
9
叉积公式 A X B= x1y2-x2y1=S(平行四边形)=2S(三角形)=2*|a|*|b|*sinaC
#include<cstdio>#include<cstring>#include<cstdlib>#include<iostream>#include<cmath>#include<functional>#include<algorithm>#include<queue>using namespace std;#define MAXN (100+10)class _vector{public:int x,y;_vector():x(0),y(0){}_vector(int _x,int _y):x(_x),y(_y){}friend int operator*(const _vector a,const _vector b) {return a.x*b.y-a.y*b.x;}}node[MAXN];istream& operator>>(istream& in,_vector& a){in>>a.x>>a.y;return in;}int n;int main(){freopen("area.in","r",stdin);freopen("area.out","w",stdout);scanf("%d",&n);for (int i=1;i<=n;i++) cin>>node[i];node[n+1]=node[1];int ans=0;for (int i=1;i<=n;i++)ans+=node[i]*node[i+1];ans=abs(ans);printf("%d\n",int(round(double(ans)/2)));//while (1);return 0;}
- 求面积 (坐标叉积公式+凹多边形面积-坐标公式)
- 求多边形面积公式(已知顶点坐标)
- 经纬度坐标下的球面多边形面积计算公式
- 求多边形面积(已知坐标)
- 已知坐标求多边形面积
- 求多边形面积(叉乘法、海伦公式)
- 使用行列式公式求多边形面积
- 多边形面积公式
- 多边形面积计算公式
- 多边形面积公式
- 多边形面积公式证明
- 多边形面积计算公式
- 多边形面积计算公式
- HDU1115 多边形面积公式
- 任意多边形面积公式
- 根据闭合的多边形坐标求面积
- 用定点坐标求,多边形面积
- 已知多边形顶点坐标求面积
- 泛型
- Web的优化
- Project Euler 13 first try
- 信息熵
- 运行VuGen时提示:ThumbsProcess.exe应用程序错误
- 求面积 (坐标叉积公式+凹多边形面积-坐标公式)
- mysql my.cnf 配置建议
- PHP正则表达式的快速学习方法
- 【吐槽】 我觉得emacs的排版有问题……
- 逝流年沧桑伤感日志_安静得,脑袋总在回忆从前
- Weka开发
- deleted object would be re-saved by cascade (remove deleted object from asso错误
- 【开源自动化测试疑难FAQ】【WebDriver】WebDriver对SWFUpload的无奈之举
- 文件的上传