题目传送门:https://arc076.contest.atcoder.jp/tasks/arc076_c

题目大意:

给定一个\(R×C\)的矩阵,然后给定\(N\)对点,每对点坐标为\((X_{i,1},Y_{i,1})\)和\((X_{i,2},Y_{i,2})\),每对点之间需要连一条线,线不能越出矩阵边界,也不能相交,问是否可能?


只有一对点都在矩阵边缘上,才可能截断其他点对的连线,那么我们从任意一个地方断开矩阵,将其展开为一条线段,那么点对相当于覆盖了线段上的一段区间,于是题目变成了区间判交问题

/*program from Wolfycz*/
#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define Fi first
#define Se second
#define MK make_pair
#define inf 0x7f7f7f7f
using namespace std;
typedef long long ll;
typedef unsigned int ui;
typedef pair<int,int> pii;
typedef unsigned long long ull;
inline char gc(){
static char buf[1000000],*p1=buf,*p2=buf;
return p1==p2&&(p2=(p1=buf)+fread(buf,1,1000000,stdin),p1==p2)?EOF:*p1++;
}
inline int frd(){
int x=0,f=1; char ch=gc();
for (;ch<'0'||ch>'9';ch=gc()) if (ch=='-') f=-1;
for (;ch>='0'&&ch<='9';ch=gc()) x=(x<<3)+(x<<1)+ch-'0';
return x*f;
}
inline int read(){
int x=0,f=1; char ch=getchar();
for (;ch<'0'||ch>'9';ch=getchar()) if (ch=='-') f=-1;
for (;ch>='0'&&ch<='9';ch=getchar()) x=(x<<3)+(x<<1)+ch-'0';
return x*f;
}
inline void print(int x){
if (x<0) putchar('-'),x=-x;
if (x>9) print(x/10);
putchar(x%10+'0');
}
const int N=1e5;
int R,C,n,Mpcnt,tot,top;
pii A[(N<<1)+10];
bool check(int x,int y){return x==0||x==R||y==0||y==C;}
int stack[(N<<1)+10];
int get(int x,int y){
if (y==0) return x;
if (x==R) return R+y;
if (y==C) return 2*R+C-x;
if (x==0) return 2*R+2*C-y;
return 0;
}
int main(){
R=read(),C=read(),n=read();
for (int i=1;i<=n;i++){
int x1=read(),y1=read(),x2=read(),y2=read();
if (!check(x1,y1)||!check(x2,y2)) continue;
int x=get(x1,y1),y=get(x2,y2);
A[++tot]=MK(x,i);
A[++tot]=MK(y,i);
}
sort(A+1,A+1+tot);
for (int i=1;i<=tot;i++){
stack[++top]=i;
if (A[stack[top]].Se==A[stack[top-1]].Se) top-=2;
}
printf(top?"NO\n":"YES\n");
return 0;
}

最新文章

  1. java springMVC SSM 操作日志 4级别联动 文件管理 头像编辑 shiro redis
  2. 缩略信息是: sending message to a Handler on a dead thread 我是用IntentService时报的
  3. jQuery动态设置样式List item
  4. 转载一篇文章 python程序员经常犯的10个错误
  5. 柯南君:看大数据时代下的IT架构(9)消息队列之RabbitMQ--案例(RPC起航)
  6. cmd命令 拷贝某文件夹及其子文件夹文件到其它文件夹
  7. BZOJ 1531: [POI2005]Bank notes( 背包 )
  8. iOS开发下架在AppStore中销售的app
  9. &lt;Natural Language Processing with Python&gt;学习笔记二
  10. MySQL数据库入门(建库和建表)--陈远波
  11. kali权限提升之本地提权
  12. 第一册:lesson 101。
  13. git 常用操作,下拉,提交,更新,还原
  14. &quot;BLAME&quot; is out.
  15. 网络流24T
  16. python调用mediainfo工具批量提取视频信息
  17. 系统对接API调用
  18. iOS几个功能:1.摇一摇;2.震动;3.简单的摇动动画;4.生成二维码图片;5.发送短信;6.播放网络音频等
  19. To B服务想做移动化?腾讯云案例了解一下
  20. 转 maven3常用命令、java项目搭建、web项目搭建详细图解

热门文章

  1. Object类及其常用方法简介
  2. linux输入子系统(6)-input子系统介绍及结构图
  3. excel 创建数据有效性及背景颜色
  4. python day- 7 进本数据类型的先关知识点 set集合 深浅拷贝
  5. Mac 下如何安装pip 和xlwt
  6. Awesome Adb——一份超全超详细的 ADB 用法大全【转】
  7. CodeChef:Little Elephant and Colored Coins
  8. mongodb mongod 参数解释
  9. SPOJ:Divisors of factorial (hard) (唯一分解&amp;分块优化)
  10. SPOJ:Robot(数学期望)