关闭

[POJ1113]Wall(凸包)

183人阅读 评论(0) 收藏 举报
分类:

题目描述

传送门
题意:给出一个多边形,要在外围距离r围一圈围墙,求围墙的长度

题解

nπ(n3)π=2π
所以就是求凸包周长然后加上一个圆周的长
从图里很清楚能看出来
Graham求凸包裸题

代码

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
#define N 1005

const double pi=acos(-1.0);
const double eps=1e-9;
int dcmp(double x)
{
    if (x<=eps&&x>=-eps) return 0;
    return (x>0)?1:-1;
}
struct Vector
{
    double x,y;
    Vector(double X=0,double Y=0)
    {
        x=X,y=Y;
    }
    bool operator < (const Vector a) const
    {
        return x<a.x||(x==a.x&&y<a.y);
    }
};
typedef Vector Point;
Vector operator - (Vector A,Vector B) {return Vector(A.x-B.x,A.y-B.y);}

int n,top;
double r,x,y,ans;
Point p[N],stack[N];

double Dot(Vector A,Vector B)
{
    return A.x*B.x+A.y*B.y;
}
double Cross(Vector A,Vector B)
{
    return A.x*B.y-A.y*B.x;
}
double Len(Vector A)
{
    return sqrt(Dot(A,A));
}
void Graham()
{
    sort(p+1,p+n+1);
    for (int i=1;i<=n;++i)
    {
        while (top>1&&dcmp(Cross(stack[top]-stack[top-1],p[i]-stack[top-1]))<=0)
            --top;
        stack[++top]=p[i];
    }
    int k=top;
    for (int i=n-1;i>=1;--i)
    {
        while (top>k&&dcmp(Cross(stack[top]-stack[top-1],p[i]-stack[top-1]))<=0)
            --top;
        stack[++top]=p[i];
    }
    if (n>1) --top;
}
int main()
{
    freopen("input.in","r",stdin);
    scanf("%d%lf",&n,&r);
    for (int i=1;i<=n;++i)
    {
        scanf("%lf%lf",&x,&y);
        p[i]=Point(x,y);
    }
    Graham();
    for (int i=1;i<=top;++i)
        ans+=Len(stack[i]-stack[i%top+1]);
    ans+=2.0*pi*r;
    printf("%.0lf\n",ans);
}
0
0
查看评论

poj1113Wall【凸包】

Language: Default Wall Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 32437   Accepted:&#...
  • R1986799047
  • R1986799047
  • 2015-09-06 13:38
  • 931

POJ 1113 Wall 凸包(模板题)

用不严谨的话来讲,给定二维平面上的点集,凸包就是将最外层的点连接起来构成的凸多边型,它能包含点集中所有的点。 题意:给出n个点 n=L? 若不考虑L 则答案为凸包的周长,考虑条件L,由如下图形 答案为:凸包周长+以L为半径的圆的周长   求凸包用的是 Graham&#...
  • Jeremy1149
  • Jeremy1149
  • 2017-04-18 15:50
  • 387

POJ1113 Wall 凸包

Description Once upon a time there was a greedy King who ordered his chief Architect to build a wall around the King's castle. The King was s...
  • a305657
  • a305657
  • 2013-01-31 22:44
  • 314

POJ1113——WALL 凸包

调了两个小时(吐 poj1113 凸包有毒啊??? 我闲的蛋疼用了一个函数叫atan2 然而这个东西用法有点神奇。。是用来求极角的 atan2(y,x) 注意是y,x 得到的是(x,y)点对对于0,0的弧度!注意是弧度! 弧度转化角度:#define atan2(x,y) atan2(x...
  • Fop_zz
  • Fop_zz
  • 2017-04-18 15:41
  • 147

poj1113 Wall【凸包】

题目链接:http://poj.org/problem?id=1113 题意:给你一个多边形,让你在距离他x的地方围一圈有弧形的矩形,让你求这个矩形的周长 解析:其实就是凸包边长,加上半径为x的圆的面积#include <iostream> #include <cstdio&g...
  • Richie_ll
  • Richie_ll
  • 2017-04-18 17:11
  • 237

poj1113 Wall 凸包

DescriptionOnce upon a time there was a greedy King who ordered his chief Architect to build a wall around the King’s castle. The King was so greedy, ...
  • xtulollipop
  • xtulollipop
  • 2015-08-07 20:42
  • 354

POJ1113浅析——Wall ——凸包

题目大意:         要在一座城堡周围建围墙,要求用料最省。围墙距城堡不得小于 距离 L。 浅析:         题目要求用料最省,求围墙长度。因...
  • monkey7777
  • monkey7777
  • 2012-08-01 17:02
  • 269

【凸包_Graham】Wall POJ1113

Wall Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 25230   Accepted: 8405 Description Once up...
  • jiangzh7
  • jiangzh7
  • 2013-04-14 08:08
  • 492

[POJ1113]Wall(计算几何-凸包)

题目: 我是超链接 题意: 给出一个多边形,要在外围距离r围一圈围墙,求围墙的最小长度 题解: 这个多边形肯定是个凸包啊,但是这个外围距离?!看个图冷静一下,图引自这位up 所以所求长度如图所示为凸包周长加以l为半径的圆的周长。因为绕周长一周所以为一个正圆 这里给出凸包求法: ...
  • Blue_CuSO4
  • Blue_CuSO4
  • 2018-01-18 19:32
  • 32

poj1113——Wall(凸包)

DescriptionOnce upon a time there was a greedy King who ordered his chief Architect to build a wall around the King’s castle. The King was so greedy, ...
  • blue_skyrim
  • blue_skyrim
  • 2017-02-26 16:16
  • 731
    个人资料
    • 访问:647611次
    • 积分:17957
    • 等级:
    • 排名:第629名
    • 原创:1151篇
    • 转载:7篇
    • 译文:0篇
    • 评论:190条
    联系方式
    QQ:1209628538 加好友请备注省份和ID
    E-mail:fiona_2000@126.com
    最新评论