ZOJ 1010 Area (判线段相交,简单多边形的面积)
来源:互联网 发布:sas分析软件 编辑:程序博客网 时间:2024/04/30 02:51
首先要判断出不合法的多边形(impossible),即与非邻边有交点的多边形,或者n<3的多边形。这里主要就是判线段相交,方法是用叉积判断一条线段的两端点是否在另一线段的两侧(跨立实验),再判断交点是否是线段所在直线上的而不是线段上的(比较线段端点的最大最小值)
第二就是计算简单多边形面积,计算方法就是计算每点和左右点对X轴的三角形面积(输入点要按逆时针排列,否则计算结果为负值)。具体情况不清楚的话画个图模拟一下就显而易见了。模版的力量是伟大的。
//Memory: 232 KB//Time: 30 MS#include <iostream>#include <stdio.h>#include <math.h>using namespace std;int n;struct POINT{double x,y;};POINT p[1002];struct LINESEG{POINT s,e;};LINESEG l[1002];double multiply(POINT sp,POINT ep,POINT op){return ((sp.x-op.x)*(ep.y-op.y)-(ep.x-op.x)*(sp.y-op.y));}bool intersect(LINESEG u,LINESEG v)//判线段相交{return (max(u.s.x,u.e.x)>=min(v.s.x,v.e.x) && (max(v.s.x,v.e.x)>=min(u.s.x,u.e.x)) &&(max(u.s.y,u.e.y)>=min(v.s.y,v.e.y)) && (max(v.s.y,v.e.y)>=min(u.s.y,u.e.y)) &&(multiply(v.s,u.e,u.s)*multiply(u.e,v.e,u.s)>=0) && (multiply(u.s,v.e,v.s)*multiply(v.e,u.e,v.s)>=0 ));}double area_of_polygon()//计算面积{int i;double s;if(n<3)return 0;s=p[0].y*(p[n-1].x-p[1].x);for(i=1;i<n;i++)s+=p[i].y*(p[i-1].x-p[(i+1)%n].x);return s/2;}int main(){int cas=1,i,j;while(~scanf("%d",&n)){if(n==0)break;bool flag=true;double area=0;for(i=0;i<n;i++){scanf("%lf%lf",&p[i].x,&p[i].y);}for(i=0;i<n;i++){l[i].s=p[i];l[i].e=p[(i+1)%n];}for(i=0;i<n;i++)for(j=i+2;j<n;j++)if(intersect(l[i],l[j])){if(i==0 && j==n-1)continue;else{flag=false;break;}}if(cas!=1)printf("\n");area=area_of_polygon();area=area>0?area:-area;if(flag && area!=0){printf("Figure %d: %.2lf\n",cas,area);}else{printf("Figure %d: Impossible\n",cas);}cas++;}return 0;}
- ZOJ 1010 Area (判线段相交,简单多边形的面积)
- zoj 1010 Area 判断线段是否相交(把线段扩充一倍后 好处理) + 多边形求面积
- zoj-1010 Area 多边形判别与面积
- ZOJ--1010:Area(线段判交问题)
- zoj 1010 Area【线段相交问题】
- zoj 2551 判线段相交
- zoj 1597 Circular Area(求两圆相交的面积)
- zoj 1597 Circular Area (求两园相交面积)
- 向量叉积的应用(三角形面积,线段相交,多边形面积,多边形凹凸性)
- ZOJ 1010 Area(判定线段是否构成多边形)
- HDOJ5130 多边形和圆相交面积 最简单的模板
- hdu2892-area 求园和多边形的相交面积模板题
- POJ1645-Area(简单多边形面积计算)
- POJ 2546 & ZOJ 1597 Circular Area(求两圆相交的面积 模板)
- POJ 1654 Area 求多边形的面积
- poj1654-area 计算多边形的面积
- Area(poj1654多边形面积)
- 圆与多边形的相交面积
- Date Picker解析
- PBRT阅读:第十四章 蒙特卡罗积分I:基本概念
- arm 力天电子lpc2148无字库12864显示一行多个汉字(串行)
- 关闭Oracle死锁进程
- ZOJ题目分类
- ZOJ 1010 Area (判线段相交,简单多边形的面积)
- 几个有用的DBCC 命令
- 主题:经典的Oracle修改表结构文档
- PBRT阅读:第一章 1.1文学编程(Literate Programming)
- 一个http请求的详细过程【转】
- Android Makefile探索2
- XSLT(19) document() Function to access external xml
- 关于SAP 对生产订单的月度结算
- WINCE修改分辨率有关文件