poj 2007(凸包)
| Time Limit: 1000MS | Memory Limit: 30000K | |
| Total Submissions: 8005 | Accepted: 3798 |
Description
A closed polygon is called convex if the line segment joining any
two points of the polygon lies in the polygon. Figure 1 shows a closed
polygon which is convex and one which is not convex. (Informally, a
closed polygon is convex if its border doesn't have any "dents".)

The subject of this problem is a closed convex polygon in the
coordinate plane, one of whose vertices is the origin (x = 0, y = 0).
Figure 2 shows an example. Such a polygon will have two properties
significant for this problem.
The first property is that the vertices of the polygon will be
confined to three or fewer of the four quadrants of the coordinate
plane. In the example shown in Figure 2, none of the vertices are in the
second quadrant (where x < 0, y > 0).
To describe the second property, suppose you "take a trip" around
the polygon: start at (0, 0), visit all other vertices exactly once, and
arrive at (0, 0). As you visit each vertex (other than (0, 0)), draw
the diagonal that connects the current vertex with (0, 0), and calculate
the slope of this diagonal. Then, within each quadrant, the slopes of
these diagonals will form a decreasing or increasing sequence of
numbers, i.e., they will be sorted. Figure 3 illustrates this point.


Input
input lists the vertices of a closed convex polygon in the plane. The
number of lines in the input will be at least three but no more than 50.
Each line contains the x and y coordinates of one vertex. Each x and y
coordinate is an integer in the range -999..999. The vertex on the first
line of the input file will be the origin, i.e., x = 0 and y = 0.
Otherwise, the vertices may be in a scrambled order. Except for the
origin, no vertex will be on the x-axis or the y-axis. No three vertices
are colinear.
Output
output lists the vertices of the given polygon, one vertex per line.
Each vertex from the input appears exactly once in the output. The
origin (0,0) is the vertex on the first line of the output. The order of
vertices in the output will determine a trip taken along the polygon's
border, in the counterclockwise direction. The output format for each
vertex is (x,y) as shown below.
Sample Input
0 0
70 -50
60 30
-30 -50
80 20
50 -60
90 -20
-30 -40
-10 -60
90 10
Sample Output
(0,0)
(-30,-40)
(-30,-50)
(-10,-60)
(50,-60)
(70,-50)
(90,-20)
(90,10)
(80,20)
(60,30)
题目要从(0,0)开始,所以找到(0,0)之后再进行输出其之后的和之前的就行...凸包水
#include<stdio.h>
#include<iostream>
#include<string.h>
#include<math.h>
#include<algorithm>
using namespace std;
const int N = ;
const double pi = atan(1.0)*;
const double eps = 1e-;
struct Point
{
int x,y;
} p[N];
Point Stack[N];
int n;
int mult(Point a,Point b,Point c)
{
return (a.x-c.x)*(b.y-c.y)-(a.y-c.y)*(b.x-c.x);
}
int dis(Point a,Point b)
{
return (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y);
}
int cmp(Point a,Point b)
{
if(mult(a,b,p[])>) return ;
if(mult(a,b,p[])==&&dis(b,p[])-dis(a,p[])>eps) return ;
return ;
}
int Graham()
{
int top = ;
sort(p+,p+n,cmp);
Stack[] = p[];
Stack[] = p[];
Stack[] = p[];
for(int i=; i<n; i++)
{
while(top>=&&mult(p[i],Stack[top],Stack[top-])>=) top--;
Stack[++top]=p[i];
}
return top;
}
int main()
{
n = ;
while(scanf("%d%d",&p[n].x,&p[n].y)!=EOF)
{
n++;
//if(n==10) break;
}
//for(int i=0;i<n;i++) printf("%d %d\n",p[i].x,p[i].y);
int k=;
for(int i=; i<n; i++)
{
if(p[i].y<p[k].y||((p[i].y==p[k].y)&&(p[i].x<p[k].x))) k = i;
}
swap(p[],p[k]);
double sum=;
int top = Graham();
int temp = ;
for(int i=;i<=top;i++){
if(Stack[i].x==&&Stack[i].y==) temp = i;
}
for(int i=temp;i<=top;i++) printf("(%d,%d)\n",Stack[i].x,Stack[i].y);
for(int i=;i<temp;i++) printf("(%d,%d)\n",Stack[i].x,Stack[i].y);
}
poj 2007(凸包)的更多相关文章
- poj 2007 凸包构造和极角排序输出(模板题)
Scrambled Polygon Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 10841 Accepted: 508 ...
- POJ 2007 Scrambled Polygon 极角序 水
LINK 题意:给出一个简单多边形,按极角序输出其坐标. 思路:水题.对任意两点求叉积正负判断相对位置,为0则按长度排序 /** @Date : 2017-07-13 16:46:17 * @File ...
- poj 1873 凸包+枚举
The Fortified Forest Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 6198 Accepted: 1 ...
- poj 1113 凸包周长
Wall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 33888 Accepted: 11544 Descriptio ...
- Poj 2187 凸包模板求解
Poj 2187 凸包模板求解 传送门 由于整个点数是50000,而求凸包后的点也不会很多,因此直接套凸包之后两重循环即可求解 #include <queue> #include < ...
- POJ - 2007 极角排序(Java 实现)
POJ 2007 将所有的点按逆时针输出 import java.io.*; import java.util.*; public class Main { static class Point im ...
- Scrambled Polygon - POJ 2007(求凸包)
给一些点,这些点都是一个凸包上的顶点,以第一个点为起点顺时针把别的点拍排一下序列. 分析:最简单的极坐标排序了..................... 代码如下: ----------------- ...
- POJ 2007 Scrambled Polygon 凸包
Scrambled Polygon Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 7214 Accepted: 3445 ...
- POJ 2007 Scrambled Polygon [凸包 极角排序]
Scrambled Polygon Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 8636 Accepted: 4105 ...
随机推荐
- JVM(2)——GC算法和收集器
一.引入 上篇博客<JVM--简介>中主要介绍了JVM的内存模型,思考一下: 为什么要划分堆.栈.方法区等? 为什么把不同种类的数据信息分别存放? 答案可以分为很多很多条,这里就说一个方面 ...
- 将CRUD封装到一个工具类中
package org.zln.hibernate.utils; import org.hibernate.Session; import org.hibernate.SessionFactory; ...
- sql 先查出已知的数据或者需要的数据再筛选
sql 先查出已知的数据或者需要的数据再筛选
- 使用adobe pdf去除PDF文档中的批量雷同文本
一.问题的提出 MgoSoft tiff to pdf软件没有提供中国地区的非VISA用户的购买渠道,中国通常都是银联标识走天下,卡不是VISA买不了这样的软件, 那么, MgoSoft tiff t ...
- JSOI2008 星球大战 [并查集]
题目描述 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系. 某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球.这些星球通过特殊的以太隧 ...
- Tumblr:150亿月浏览量背后的架构挑战
Tumblr:150亿月浏览量背后的架构挑战 2013/04/08 · IT技术, 开发 · 9.9K 阅读 · HBase, Tumblr, 架构 英文原文:High Scalability,编译: ...
- Kafka自我学习1-Multi-broker cluster
====================================Testing environment =========================================== ...
- 深入探索 高效的Java异常处理框架
转载自:http://www.sunwei.org/archives/196 摘要:本文从Java异常最基本的概念.语法开始讲述了Java异常处理的基本知识,分析了Java异常体系结构,对比Sprin ...
- MySQL远程访问权限 允许远程连接
1 首先cd / 到根目录,打开mysql控制台 登录数据库 mysql -u root -p 2.授权远程连接 mysql> use mysql; Database changed mysq ...
- windows 系统下git 的使用
前言: 最新版本的git for windows也是有界面的,不再是以前的纯命令行操作,但是我习惯了乌龟,所以感觉还是直接用乌龟比较方便点~~ 前提,已安装以下: git for windows,未安 ...