博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
cogs896 圈奶牛(凸包)
阅读量:4363 次
发布时间:2019-06-07

本文共 1500 字,大约阅读时间需要 5 分钟。

描述

农夫约翰想要建造一个围栏用来围住他的奶牛,可是他资金匮乏。他建造的围栏必须包括他的奶牛喜欢吃草的所有地点。对于给出的这些地点的坐标,计算最短的能够围住这些点的围栏的长度。

PROGRAM NAME: fc

INPUT FORMAT(file fc.in)

输入数据的第一行包括一个整数 N。N(0 <= N <= 10,000)表示农夫约翰想要围住的放牧点的数目。接下来 N 行,每行由两个实数组成,Xi 和 Yi,对应平面上的放牧点坐标(-1,000,000 <= Xi,Yi <= 1,000,000)。数字用小数表示。

OUTPUT FORMAT(file fc.out)

输出必须包括一个实数,表示必须的围栏的长度。答案保留两位小数。

SAMPLE INPUT (file fc.in)

4
4 8
4 12
5 9.3
7 8
SAMPLE OUTPUT (file fc.out)
12.00

凸包裸体,人生中第一次计算几何(一A O(∩_∩)O~)

推荐博客:圈奶牛/

这里写代码片#include
#include
#include
#include
#include
using namespace std;const double eps=1e-7;struct node{ double x,y;};node po[10010];int top,sta[20010];int n;int dcmp(double x) //精度控制 { if (fabs(x)
0) return 1; else return -1;}int cmp(const node &a,const node &b){ if (dcmp(a.x-b.x)!=0) return a.x
1&&dcmp(cross(i,sta[top],sta[top-1]))<=0) top--; sta[++top]=i; } //下凸壳 int k=top; for (i=n-1;i>=1;i--) { while (top>k&&dcmp(cross(i,sta[top],sta[top-1]))<=0) top--; sta[++top]=i; } //上凸壳 if (n>1) top--; //如果n>1,1号点会被算两遍,所以这里需要-- double ans=0; ans+=dis(sta[1],sta[top]); while (top>1) ans+=dis(sta[top],sta[top-1]),top--; //top>1!!! printf("%0.2lf",ans); return;}int main(){ freopen("fc.in","r",stdin); //cogs支持文件读写 freopen("fc.out","w",stdout); scanf("%d",&n); for (int i=1;i<=n;i++) scanf("%lf%lf",&po[i].x,&po[i].y); sort(po+1,po+1+n,cmp); //水平排序,操作简单 TuB(); return 0;}

转载于:https://www.cnblogs.com/wutongtong3117/p/7673624.html

你可能感兴趣的文章
单例对象的创建与销毁
查看>>
知识点关键词(记录一下)
查看>>
国际结算业务
查看>>
嵌套循环概念
查看>>
ASP.NET MVC Model绑定(二)
查看>>
一步一步写算法(之hash表)
查看>>
漫谈并发编程(一) - 并发简单介绍
查看>>
JDBC连接MySQL数据库及演示样例
查看>>
Beta 冲刺(1/7)
查看>>
修改 Vultr 登录密码
查看>>
CSS学习
查看>>
Centos 安装lnmp完整版
查看>>
【转】Eclipse和PyDev搭建完美Python开发环境(Ubuntu篇)
查看>>
Differences between page and segment
查看>>
字符串之strcmp
查看>>
最长公共子序列(不连续)
查看>>
微服务:Java EE的拯救者还是掘墓人?
查看>>
如何在Centos里面,把.net core程序设为开机自启动
查看>>
1920*1080pc端适配
查看>>
Nutch系列1:简介
查看>>