[xsy2238]snake
题意:给定一条折线,问能否在不扭曲它的情况下让它完全通过一个小孔
这个条件就是:过折线上任意一点$x$存在一条直线把折线分成不与直线相交的两部分,换句话说存在(与折线只有一个交点$x$)的直线
结论是:若点$i$严格在点$1\cdots i$或点$i\cdots n$构成的凸包内,则无解,因为过点$i$的直线必然与折线在其他的某些位置相交
所以我们可以用set维护仅插入动态凸包,边插入边查询即可
实际上没有必要维护整个凸包,只维护原来的点还有它关于原点对称点的上凸壳就可以了
注意C++做布尔运算的短路机制==
#include<stdio.h> #include<set> using namespace std; typedef long long ll; struct point{ int x,y; point(int a=0,int b=0){x=a;y=b;} }p[100010]; point operator-(point a,point b){return point(a.x-b.x,a.y-b.y);} ll operator*(point a,point b){return(ll)a.x*b.y-(ll)a.y*b.x;} struct cmp{ bool operator()(point a,point b){return a.x==b.x?a.y<b.y:a.x<b.x;} }; struct conv{ typedef set<point,cmp> st; typedef st::iterator si; st s; si it; si pre(si i){ i--; return i; } si nex(si i){ i++; return i; } point d[100010]; int M,siz; void clear(){s.clear();siz=0;} bool insert(point p){ it=s.lower_bound(p); if(it!=s.begin()&&it!=s.end()&&(p-*pre(it))*(*it-p)>=0)return 0; M=0; if(it!=s.begin()){ it--; while(it!=s.begin()&&(*it-*pre(it))*(p-*it)>=0)d[++M]=*(it--); } it=s.lower_bound(p); if(it!=s.end()){ while(nex(it)!=s.end()&&(*it-p)*(*nex(it)-*it)>=0)d[++M]=*(it++); } while(M)s.erase(d[M--]); s.insert(p); siz=s.size(); return 1; } }c1,c2; int n; void work(){ int i; bool f1,f2; for(i=1;i<=n;i++)scanf("%d%d",&p[i].x,&p[i].y); c1.clear(); c2.clear(); for(i=1;i<=n;i++){ f1=!c1.insert(p[i]); f2=!c2.insert(0-p[i]); if(f1&&f2){ puts("Impossible"); return; } } c1.clear(); c2.clear(); for(i=n;i>0;i--){ f1=!c1.insert(p[i]); f2=!c2.insert(0-p[i]); if(f1&&f2){ puts("Impossible"); return; } } puts("Possible"); } int main(){ while(~scanf("%d",&n))work(); }
[xsy2238]snake的更多相关文章
- [LeetCode] Design Snake Game 设计贪吃蛇游戏
Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...
- Leetcode: Design Snake Game
Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...
- 2101 Problem A Snake Filled
题目描述 “What a boring world!”Julyed felt so bored that she began to write numbers on the coordinate pa ...
- 图像分割之(五)活动轮廓模型之Snake模型简介
在"图像分割之(一)概述"中咱们简单了解了目前主流的图像分割方法.下面咱们主要学习下基于能量泛函的分割方法.这里学习下Snake模型简单的知识,Level Set(水平集)模型会在 ...
- Epic - Snake Sequence
You are given a grid of numbers. A snakes equence is made up of adjacent numbers such that for each ...
- Codeforces Round #290 (Div. 2) A. Fox And Snake 水题
A. Fox And Snake 题目连接: http://codeforces.com/contest/510/problem/A Description Fox Ciel starts to le ...
- 图像切割之(五)活动轮廓模型之Snake模型简单介绍
图像切割之(五)活动轮廓模型之Snake模型简单介绍 zouxy09@qq.com http://blog.csdn.net/zouxy09 在"图像切割之(一)概述"中咱们简单了 ...
- 353. Design Snake Game
贪食蛇. GAME OVER有2种情况,1是咬到自己,2是出界. 1)用QUEUE来保留占据的格子,每走一格就添加1个,然后POll()最后一个. 做一个一样的SET来check要走的格子是不是已经在 ...
- 切割图像(五)主动轮廓模型Snake简要模型
切割图像(五)主动轮廓模型Snake简要模型 zouxy09@qq.com http://blog.csdn.net/zouxy09 在"图像切割之(一)概述"中咱们简单了解了眼下 ...
随机推荐
- DotNet 学习笔记 Servers
Servers ASP.NET Core ships with two different HTTP servers: •Microsoft.AspNetCore.Server.Kestrel (AK ...
- hdu 2059 龟兔赛跑(动态规划DP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2059 龟兔赛跑 Time Limit: 1000/1000 MS (Java/Others) M ...
- Mimikatz.ps1本地执行
PS C:\Users\hacker> Get-ExecutionPolicy Restricted PS C:\Users\hacker> Set-ExecutionPolicy Unr ...
- HTML5 audio标签自制音乐播放器
相关技能 HTML5+CSS3(实现页面布局和动态效果) Iconfont(使用矢量图标库添加播放器相关图标) LESS (动态CSS编写) jQuery(快速编写js脚本) gulp+webpack ...
- 虚拟存储管理中几种缺页中断算法(最佳置换法OPT)
缺页中断就是要访问的页不在主存,需要操作系统将其调入主存后再进行访问. 在进行内存访问时,若所访问的页已在主存,则称此次访问成功: 若所访问的页不在主存,则称此次访问失败,并产生缺页中断. 最佳置换法 ...
- HDU-5384
Danganronpa Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Tot ...
- [PAT] 1142 Maximal Clique(25 分)
1142 Maximal Clique(25 分) A clique is a subset of vertices of an undirected graph such that every tw ...
- 导出数据到word
打野的时候,碰到一个需求,导出简历信息. 两条思路: 第一条,直接画所有的表格,填充数据. 第二条,加载一个空的模板,然后填充数据. 因为导出的有格式的,所以最后选择了使用模板进行替换,然后填充数据. ...
- Python基础系列----环境的搭建及简单输入、输出
1.Python 以下信 ...
- python spyder 今天突然打不开了【已解决】
python spyder 我是设置开机启动的,先出现dos窗口,然后是蜘蛛网,后面就什么都没有了.然后百度了半天,在csdn看到一篇文章,试了一下,内牛满面! 方法:C:\Documents and ...