CFCF2055F.Cosmic Divide
省选/NOI-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
手握神器,现实的纤维向其真正的主人——Florida Man——屈服。
多连方(polyomino)是由一个或多个相等的 1×1 单元格通过边相连组成的连通图形。若对于多连方中任意两个在同一行或同一列的单元格,所有位于它们之间的单元格也都属于该多连方,则称其为凸多连方。下图展示了四个多连方,只有第一个和第二个是凸的。

你得到一个具有 n 行且面积为偶数的凸多连方。对于每一行 i(1≤i≤n),从第 li 列到第 ri 列的单元格都属于该多连方。换句话说,第 i 行包含 ri−li+1 个属于多连方的单元格,分别为 (i,li),(i,li+1),…,(i,ri−1),(i,ri)。
如果两个多连方经过平移后可以完全重合,则称它们全等。注意,不允许旋转或翻转多连方。
请判断是否可以将给定的凸多连方划分为两个不相交且连通的多连方,并且这两个多连方全等。下图展示了题目描述中前两个凸多连方的合法划分示例:

划分后得到的多连方不要求是凸的,并且每个单元格必须恰好属于其中一个划分出的多连方。
∗ 若对于多连方中任意两个不同的单元格 u=v,存在一条由若干不同单元格 s1,s2,…,sk 组成的路径,使得 s1=u,sk=v,所有 si 都属于该多连方,且对于每个 1≤i≤k−1,si 与 si+1 共享一条边,则称该多连方是连通的。
输入格式
每组测试数据包含多个测试用例。第一行包含一个整数 t(1≤t≤104),表示测试用例的数量。
每个测试用例的第一行包含一个整数 n(1≤n≤2×105),表示多连方的行数。
接下来的 n 行,每行包含两个整数 li 和 ri(1≤li≤ri≤109),表示第 i 行属于多连方的列区间。
保证多连方的面积为偶数,即 ∑i=1n(ri−li+1)≡0(mod2)。
保证所有测试用例中 n 的总和不超过 2×105。
输出格式
对于每个测试用例,输出一行 "YES" 或 "NO",表示是否可以按题目要求划分该多连方。
你可以以任意大小写输出答案,例如 "yEs"、"yes"、"Yes" 和 "YES" 都会被识别为肯定回答。
输入输出样例
输入#1
7 2 1 2 2 3 4 4 4 2 4 1 4 1 2 3 1 2 1 2 2 3 2 1 3 3 3 2 1 3 2 2 3 1 2 1 3 1 3 4 8 9 6 8 6 8 5 6
输出#1
YES YES NO NO NO NO YES
说明/提示
前两个测试用例对应题目描述中的多连方,并且可以如图所示进行划分。
第三个测试用例对应的多连方如下图所示,可以证明无法按要求划分。下图中的两种划分都不合法:

左侧的划分得到的多连方不是平移全等的,右侧的划分得到的多连方不是连通的。
第四个测试用例对应的多连方如下图所示,也无法按要求划分。

注意,虽然可以将其划分为两个 1×2 的矩形,但这两个矩形不是平移全等的。