传送门:http://arc076.contest.atcoder.jp/tasks/arc076_c

平面上有一个R×C的网格,格点上可能写有数字1~N,每个数字出现两次。现在用一条曲线将一对相同的数字连接,对于数字1~N。试判断是否存在一种连接方式,使得曲线不越过矩形网格边界,且曲线之间不相交?

若平面网格为无限大,则使得曲线之间不相交的连接方式一定存在。因此,在一个R×C的网格上,优先考虑边界上的点对,再考虑不全在边界上的点对。将两次均处于边界上的数字的集合记为S

由于曲线不越过网格边界,因此规定曲线均位于边界内侧。以下只需考虑曲线是否相交。

设集合S中的元素i,j,在边界上出现的顺序为i,j,i,j,则连接i点对的曲线与连接j点对的曲线一定相交;若出现的顺序为i,i,j,ji,j,j,i,则连接i点对的曲线与连接j点对的曲线不相交。因此,可以考虑用栈(Stack)实现边界点对的检验:沿顺时针方向遍历边界上的点对,若当前栈不为空,且栈顶元素与当前位置的数字相同,则将栈顶元素弹出;否则将当前位置的数字压入栈。如此,若最终栈为空,则答案为YES,否则为NO。

参考程序如下:

#include <bits/stdc++.h>
using namespace std; #define MAX_N 100010 int r, c, n;
stack<int> s;
struct point {int id, coor;} p[][ * MAX_N]; int boundary(int x, int y)
{
if (x == ) return ;
else if (y == c) return ;
else if (x == r) return ;
else if (y == ) return ;
else return -;
} bool cmp_inc(point a, point b)
{
return a.coor < b.coor;
} bool cmp_dec(point a, point b)
{
return a.coor > b.coor;
} int main(void)
{
scanf("%d%d%d", &r, &c, &n);
int cnt[] = {};
for (int i = ; i <= n; i++) {
int x[], y[];
scanf("%d%d%d%d", &x[], &y[], &x[], &y[]);
bool is_boundary = true;
for (int j = ; j < ; j++) {
if (x[j] % r && y[j] % c) is_boundary = false;
}
if (is_boundary) {
for (int j = ; j < ; j++) {
int t = boundary(x[j], y[j]);
p[t][cnt[t]].id = i;
p[t][cnt[t]].coor = t % ? x[j]: y[j];
cnt[t]++;
}
}
}
for (int i = ; i < ; i++) {
if (i < ) sort(p[i], p[i] + cnt[i], cmp_inc);
else sort(p[i], p[i] + cnt[i], cmp_dec);
for (int j = ; j < cnt[i]; j++) {
if (s.size() && s.top() == p[i][j].id)
s.pop();
else
s.push(p[i][j].id);
}
}
if (s.empty()) printf("YES\n");
else printf("NO\n");
return ;
}

AtCoder ARC 076E - Connected?的更多相关文章

  1. 【题解】Atcoder ARC#90 F-Number of Digits

    Atcoder刷不动的每日一题... 首先注意到一个事实:随着 \(l, r\) 的增大,\(f(r) - f(l)\) 会越来越小.考虑暴力处理出小数据的情况,我们可以发现对于左端点 \(f(l) ...

  2. AtCoder ARC 076D - Built?

    传送门:http://arc076.contest.atcoder.jp/tasks/arc076_b 本题是一个图论问题——Manhattan距离最小生成树(MST). 在一个平面网格上有n个格点, ...

  3. AtCoder ARC 082E - ConvexScore

    传送门:http://arc082.contest.atcoder.jp/tasks/arc082_c 本题是一个平面几何问题. 在平面直角坐标系中有一个n元点集U={Ai(xi,yi)|1≤i≤n} ...

  4. Atcoder ARC 082C/D

    C - Together 传送门:http://arc082.contest.atcoder.jp/tasks/arc082_a 本题是一个数学问题. 有一个长度为n的自然数列a[1..n],对于每一 ...

  5. 【题解】 AtCoder ARC 076 F - Exhausted? (霍尔定理+线段树)

    题面 题目大意: 给你\(m\)张椅子,排成一行,告诉你\(n\)个人,每个人可以坐的座位为\([1,l]\bigcup[r,m]\),为了让所有人坐下,问至少还要加多少张椅子. Solution: ...

  6. 【题解】Atcoder ARC#96 F-Sweet Alchemy

    首先,我们发现每一个节点所选择的次数不好直接算,因为要求一个节点被选择的次数大于等于父亲被选择的次数,且又要小于等于父亲被选择的次数 \(+D\).既然如此,考虑一棵差分的树,规定每一个节点被选择的次 ...

  7. AtCoder ARC 090 E / AtCoder 3883: Avoiding Collision

    题目传送门:ARC090E. 题意简述: 给定一张有 \(N\) 个点 \(M\) 条边的无向图.每条边有相应的边权,边权是正整数. 小 A 要从结点 \(S\) 走到结点 \(T\) ,而小 B 则 ...

  8. 【题解】Atcoder ARC#67 F-Yakiniku Restaurants

    觉得我的解法好简单,好优美啊QAQ 首先想想暴力怎么办.暴力的话,我们就枚举左右端点,然后显然每张购物券都取最大的值.这样的复杂度是 \(O(n ^{2} m)\) 的.但是这样明显能够感觉到我们重复 ...

  9. 【题解】Atcoder ARC#85 E-MUL

    ……没啥可说的.最大权闭合子图,跑下dinic就好了…… #include <bits/stdc++.h> using namespace std; #define maxn 500000 ...

随机推荐

  1. Mysql查看sql是否走事务

    登陆进入server [root@gzmtest_25 ~]# su - mysql [mysql@gzmtest_25 ~]$ mysql.local Welcome to the MySQL mo ...

  2. window.open()方法(弹出层)

    1, 最主要的弹出窗体代码    window.open('page.html'); 2, 经过设置后的弹出窗体    window.open('page.html', 'newwindow', 'h ...

  3. 关注C-RAN 的五大理由

     关注C-RAN的五大理由 Scott Wakelin 近期行业媒体上有大量关于移动网络运营商(如美国的VerizonWireless和AT&T.法国电信以及中国移动等)怎样在着力探索一种 ...

  4. EasyUI DataGrid组织事件冒泡

    在事件内部需要阻止的地方添加如下代码 ]; 解释: arguments.callee是获得我自定义的事件处理方法OnSelected的方法体. .caller是获得调用OnSelected的上层方法( ...

  5. do…while语句

    有些情况下,不论条件是否满足,循环过程必须至少执行一次,这时可以采用do...while语句.就像如图7.4所示登录账号一样,需要先输入密码和账户名,后进行判断:如果密码始终不正确,则循环要求用户输入 ...

  6. Shiny学习实践01

    Shiny是什么东东? 官方描述: Shiny is an R package that makes it easy to build interactive web apps straight fr ...

  7. 【SQL】IN、EXISTS和表连接三者的效率比较

    一. IN和EXISTS比较 在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行查询.此时就会用到IN和EXISTS. 例如:查询departments表中存在的部门的人数. 1. 使 ...

  8. Deutsch lernen (05)

    1. die Wahrheit, -en 真理:  - 真言,实情 Wir sollen die Wahrheit festhalten. 坚持:紧握 Im Wein liegt Wahrheit. ...

  9. javascript 基础知识点

    NaN; // NaN表示Not a Number,当无法计算结果时用NaN表示 Infinity; // Infinity表示无限大,当数值超过了JavaScript的Number所能表示的最大值时 ...

  10. 【sqli-labs】 less9 GET - Blind - Time based. - Single Quotes (基于时间的GET单引号盲注)

    加and http://localhost/sqli/Less-9/?id=1' and '1'='1%23 http://localhost/sqli/Less-9/?id=1' and '1'=' ...