SGU 128.Snake
时间限制:0.25s
空间限制:4m
题意:
在一个平面坐标中有N个点,现在要你用这N个点构造一个闭合图形,这个图形要满足以下条件:
1.这个图形要是闭合的;
2.图形上的点只能是给定的点,且每个点只能用一次;
3.每个顶点相连的两条边必须互相垂直;
4.每条边都要平行于坐标轴;
5.每条线除了顶点外都不能互相相交;
6.闭合图形的周长要最小;
N-----点的个数
接下来N个点。
如果存在则输出最小长度;否则输出0。
Solution:
重点在所求图形所有的边都是平行于X轴或Y轴,那么要使所有点成直角,只要对所有点先对X轴再对Y轴排序
很容易发现对于在同一条竖线方向和同一条横线方向的点,一定是两个两个点相连。
现在问题是如何判断线段相交的情况
假如现在已经连接完所有竖直方向的边,接着我们连接横向的边,两点为(x1,y,x2,y),
如果存在一条竖直边(a,b1,a,b2) 使得x1<x<x2 且 b1<y<b2 那么这两条边相交
于是可以将排完序的所有的相同的x分为一组,如果x1,和x2所在的组内还有别的组的话即使得x1<x<x2 ,
就将那些组的边取出来,再判断 是否 b1<y<b2 是否满足,最后再判断得的的是否是只有一个闭合曲线,并查集即可。
参考代码:
#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std;
const int INF = 11111;
struct node {
int x, y, Pxy, Pyx;
};
int f[INF];
node Axy[INF], Ayx[INF];
int pos[INF << 2], head[INF];
int n, x, y, ans;
int Find (int x) {
if (f[x] != x) return f[x] = Find (f[x]);
return x;
}
void getT (int a, int b) {
f[Find (a)] = Find (b);
}
int cmpXY (node a, node b) {
if (a.x == b.x) return a.y < b.y;
return a.x < b.x;
}
int cmpYX (node a, node b) {
if (a.y == b.y) return a.x < b.x;
return a.y < b.y;
}
int make() {
if (n & 1 ) return 0;
for (int i = 2; i <= n; i += 2) {
if (Axy[i - 1].x == Axy[i].x) {
getT (i, i - 1);
ans += Axy[i].y - Axy[i - 1].y;
}
else return 0;
}
for (int i = 2; i <= n; i += 2) {
if (Ayx[i - 1].y == Ayx[i].y) {
getT (Ayx[i - 1].Pxy, Ayx[i].Pxy);
ans += Ayx[i].x - Ayx[i - 1].x;
}
else return 0;
if (pos[Ayx[i - 1].x ] + 1 != pos[Ayx[i].x ])
for (int j = head[pos[Ayx[i - 1].x ] + 1];
j < head[pos[Ayx[i].x ]] - 1; j += 2)
if (Axy[j].y < Ayx[i].y && Ayx[i].y < Axy[j + 1].y) return 0;
}
for (int i = 2; i <= n; i++)
if (Find(i) != Find(i-1))
return 0;
return ans;
}
int main() {
scanf ("%d", &n);
for (int i = 1; i <= n; i++) {
scanf ("%d %d", &Axy[i].x, &Axy[i].y);
Axy[i].x += INF, Axy[i].y += INF;
}
sort (Axy + 1, Axy + n + 1, cmpYX);
for (int i = 1; i <= n; i++) {
Axy[i].Pyx = i;
Ayx[i] = Axy[i];
}
sort (Axy + 1, Axy + n + 1, cmpXY);
int now = -1, t = 0;
for (int i = 1; i <= n; i++) {
Ayx[Axy[i].Pyx].Pxy = i, f[i] = i;
if ( Axy[i].x != now ) {
now = Axy[i].x, head[++t] = i;
pos[now] = t;
}
}
printf ("%d", make() );
return 0;
}
SGU 128.Snake的更多相关文章
- SGU 128. Snake --- 暴力枚举+并查集+贪心+计算几何
<传送门> 128. Snake time limit per test: 0.25 sec. memory limit per test: 4096 KB There are N poi ...
- 0SGU 128 snake (&& ZOJ 3521) 尺取,排序二叉树,线段树 难度:2
128. Snake time limit per test: 0.25 sec. memory limit per test: 4096 KB There are N points given by ...
- Snake - SGU 128(构造多边形)
题目大意:有N个点,如果可以使用这N个点连接,连接的时候任意两条边要成直角,任意边都要平行于x轴或者y轴,并且不能出现跨立相交,最终组成一个闭合的多边形,求出来这个多边形的最小长度. 分析:容易证明这 ...
- SGU 分类
http://acm.sgu.ru/problemset.php?contest=0&volume=1 101 Domino 欧拉路 102 Coprime 枚举/数学方法 103 Traff ...
- SGU Volume 1
SGU 解题报告(持续更新中...Ctrl+A可看题目类型): SGU101.Domino(多米诺骨牌)------------★★★type:图 SGU102.Coprimes(互质的数) SGU1 ...
- OpenCV学习代码记录—— Snake轮廓
很久之前学习过一段时间的OpenCV,当时没有做什么笔记,但是代码都还在,这里把它贴出来做个记录. 代码放在码云上,地址在这里https://gitee.com/solym/OpenCVTest/tr ...
- SGU 205. Quantization Problem
205. Quantization Problem time limit per test: 0.25 sec. memory limit per test: 65536 KB input: stan ...
- Deep Snake : 基于轮廓调整的SOTA实例分割方法,速度32.3fps | CVPR 2020
论文提出基于轮廓的实例分割方法Deep snake,轮廓调整是个很不错的方向,引入循环卷积,不仅提升了性能还减少了计算量,保持了实时性,但是Deep snake的大体结构不够优雅,应该还有一些工作可以 ...
- 编写高质量代码:改善Java程序的151个建议(第8章:多线程和并发___建议126~128)
建议126:适时选择不同的线程池来实现 Java的线程池实现从根本上来说只有两个:ThreadPoolExecutor类和ScheduledThreadPoolExecutor类,这两个类还是父子关系 ...
随机推荐
- 利用python分析nginx日志
最近在学习python,写了个脚本分析nginx日志,练练手.写得比较粗糙,但基本功能可以实现. 脚本功能:查找出当天访问次数前十位的IP,并获取该IP来源,并将分析结果发送邮件到指定邮箱. 实现前两 ...
- 折腾iPhone的生活——通过设置使iPhone更省电
入手了iPhone5s,上手感觉iPhone没有过去省电了,可能是iOS7的关系,也有可能是我一直在下应用的关系,但是iPhone5s那1500mA的电池的确是有点真的不那么够用的样子,通过设置来省电 ...
- Google表单
本博文的主要内容有 .Google表单的介绍 https://www.google.com/intl/zh-CN/forms/about/ 自行去注册Google账号,不多,赘述.
- Ubuntu 虚拟机环境安装配置指南
1. 安装Ubuntu到虚拟机. 到 Ubuntu 上下载桌面版iso文件,加载到虚拟机,开始安装,傻瓜式操作不用多说.2. 调整屏幕分辨率. 虚拟机软件我是用的virtual box,在工具栏上设备 ...
- Digital Root - SGU 118(高精度运算)
题目大意:有K组测试数据,然后每组有N个正整数,A1,A2,A3.....An,求出 A1 + A1*A2 + A1*A2*A3 + .......A1*A2*...An 的数根. 分析:有个对9取余 ...
- C# 获取网页数据、获取本机IP 分类: C# 2014-12-16 14:59 308人阅读 评论(0) 收藏
说明: (1) http://www.3322.org/dyndns/getip 这个网址可以获取本机IP,读取的内容就是本机IP (2)方法经测试,可以实现. (3)参考:http://www.cn ...
- 关于MS office 180天后再次激活遇到的问题解决方法
遇到的问题: 再次点击miniKMS 激活软件激活失败 : 我也不知道这是为什么?后来我在同一目录重装了一次,点击的还是我以前的那个KSM激活软件,出现的错误还是一样的.于是我想可能是这个激活软件的 ...
- boost------asio库的使用1(Boost程序库完全开发指南)读书笔记
asio库基于操作系统提供的异步机制,采用前摄器设计模式(Proactor)实现了可移植的异步(或者同步)IO操作,而且并不要求多线程和锁定,有效地避免了多线程编程带来的诸多有害副作用. 目前asio ...
- mysql 源码编绎修改 FLAGS,调试MYSQL
http://dev.mysql.com/doc/refman/5.7/en/source-configuration-options.html#option_cmake_cmake_c_flags ...
- hadoop处理Excel通话记录
前面我们所写mr程序的输入都是文本文件,但真正工作中我们难免会碰到需要处理其它格式的情况,下面以处理excel数据为例 1.项目需求 有刘超与家庭成员之间的通话记录一份,存储在Excel文件中,如下面 ...