/*
poj3348 Cows 凸包+多边形面积 水题
floor向下取整,返回的是double
*/
#include<stdio.h>
#include<math.h>
#include <algorithm>
using namespace std;
const double eps = 1e-8;
struct point
{
double x,y;
};
int n;
point dian[10000+10],zhan[10000+10];
//////////////////////////////////////////////////
point *mo_dian;
double mo_distance(point p1,point p2)
{
return sqrt((p1.x-p2.x)*(p1.x-p2.x)+(p1.y-p2.y)*(p1.y-p2.y));
}
double mo_xmult(point p2,point p0,point p1)//p1在p2左返回负,在右边返回正
{
return (p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y);
} bool mo_ee(double x,double y)
{
double ret=x-y;
if(ret<0) ret=-ret;
if(ret<eps) return 1;
return 0;
}
bool mo_gg(double x,double y) { return x > y + eps;} // x > y
bool mo_ll(double x,double y) { return x < y - eps;} // x < y
bool mo_ge(double x,double y) { return x > y - eps;} // x >= y
bool mo_le(double x,double y) { return x < y + eps;} // x <= y bool mo_cmp(point a,point b) // 第一次排序
{
if( mo_ee(a.y ,b.y ) )
return mo_ll(a.x, b.x);
return mo_ll(a.y,b.y);
}
bool mo_cmp1(point a,point b) // 第二次排序
{
double len = mo_xmult(b,mo_dian[0],a);
if( mo_ee(len,0.0) )
return mo_ll(mo_distance(mo_dian[0],a),mo_distance(mo_dian[0],b));
return mo_gg(len,0.0);
}
int mo_graham(int n,point *dian,point *stk)
{
int i,top=1;
mo_dian=dian;
sort(mo_dian,mo_dian+n,mo_cmp);
sort(mo_dian+1,mo_dian+n,mo_cmp1);
stk[0]=mo_dian[0];
stk[1]=mo_dian[1];
for(i=2;i<n;++i)
{
while(top>0&&mo_xmult(mo_dian[i],stk[top-1],stk[top])<=0) --top;
stk[++top]=mo_dian[i];
}
return top+1;
}
double mo_area_polygon(point *dian,int n)
{
int i;
point yuan;
yuan.x=yuan.y=0;
double ret=0;
for(i=0;i<n;++i)
{
ret+=mo_xmult(dian[(i+1)%n],yuan,dian[i]);
}
if(ret<0) ret=-ret;
return ret/2;
}
////////
int main()
{
int i;
while(scanf("%d",&n)!=EOF)
{
for(i=0;i<n;++i)
{
scanf("%lf%lf",&dian[i].x,&dian[i].y);
}
int ret=mo_graham(n,dian,zhan);
double area=mo_area_polygon(zhan,ret);
printf("%.0lf\n",floor(area/50));
}
return 0;
}

最新文章

  1. Linux命令学习总结:rm命令
  2. jquery点击元素之外触发事件
  3. 初识The Battle of Polytopia
  4. 【原创】我所理解的自动更新-APP发布与后台发布
  5. jQuery阻止默认行为和阻止冒泡
  6. Ubuntu 12.04 和 Win7 双系统安装
  7. Gprinter Android SDK V2.1 使用说明
  8. leetcode面试准备: Jump Game II
  9. java 良好开发规范
  10. ajax分页实现,jquery.pagination.js
  11. iOS苹果官方Demo合集
  12. Vue.js源码——事件机制
  13. 解决html5 canvas 绘制字体、图片与图形模糊问题
  14. STL --&gt; set用法
  15. AXI_DMA IP学习
  16. Verilog中关于wire使用的一些小知识
  17. 转 多租户SaaS架构
  18. Py中查看数据类型【转载】
  19. POJ 2185 kmp
  20. Linux C语言编程基本原理与实践

热门文章

  1. c++的四种强制类型转换
  2. Asm.js: Javascript的编译目标
  3. 使用mysql-proxy代理实现msyql数据库读写分离
  4. TEdit,TMemo背景透明
  5. mysql优化21条经验(转)
  6. 【转】SendMessage及WPRAME、LPARAME
  7. ORACLE软件下载地址
  8. (转载)PHP json_encode() 函数介绍
  9. HDOJ 2011 多项式求和
  10. java多线程编程(2)交替输出数字和字母