\(\mathcal{Description}\)

  Link.

  数轴从 \(1\sim 2n\) 的整点上有 \(n\) 个闭区间。你只知道每个区间的部分信息(可能不知道左或右端点,或者都不知道),问是否存在满足已知信息的 \(n\) 个区间,满足:

  • 每个整点是恰好一个区间的端点。
  • 所有包含同一个整点的区间长度相等。

  输入信息可能不合法

  \(n\le100\)。

\(\mathcal{Solution}\)

  老细节题了。(

  考虑数轴上连续的一段区间 \([l,r]\),记 \(L=r-l+1\),若该区间内能够满足条件,则显然有:

  • \(2|L\)。
  • \([i,i+\frac{L}2]\) 可以存在于区间集合中。

  记 \(f(i)\) 表示 \(1\sim i\) 能否合法,\(\mathcal O(n^3)\) 暴力转移即可。

  但这个不是难点,if-else 才是难点 qwq。

  • 输入可能多点重合,判否。
  • 若有区间 \([l,?]\) 和 \([?,r]\),注意不能让 \(l\) 和 \(r\) 组成 \([l,r]\)。

  对于第二点,一组 CF 上的 hack 数据为:

  1. 2
  2. 1 -1
  3. -1 3
  4. answer: No

  多堆几个 if-else 就 A 啦!(

\(\mathcal{Code}\)

  1. /* Clearink */
  2. #include <cstdio>
  3. #include <cstdlib>
  4. #include <assert.h>
  5. const int MAXN = 200;
  6. int n, match[MAXN + 5];
  7. bool f[MAXN + 5], vis[MAXN + 5];
  8. inline bool check ( const int l, const int r ) {
  9. int stp = r - l + 1 >> 1; // i -> i + stp.
  10. for ( int i = l, j; ( j = i + stp ) <= r; ++ i ) {
  11. bool acci = 1 <= match[i] && match[i] <= n << 1;
  12. bool accj = 1 <= match[j] && match[j] <= n << 1;
  13. if ( match[i] == -1 || ( acci && match[i] ^ j )
  14. || match[j] == ( n << 1 | 1 ) || ( accj && match[j] ^ i )
  15. || ( !acci && !accj && match[i] && match[j] ) ) {
  16. return false;
  17. }
  18. }
  19. return true;
  20. }
  21. int main () {
  22. scanf ( "%d", &n );
  23. for ( int i = 1, a, b; i <= n; ++ i ) {
  24. scanf ( "%d %d", &a, &b );
  25. if ( ~a && ~b && a >= b ) return puts ( "No" ), 0;
  26. if ( ~a && ~b ) match[a] = b, match[b] = a;
  27. else if ( ~a ) match[a] = n << 1 | 1;
  28. else if ( ~b ) match[b] = -1;
  29. if ( ~a ) {
  30. if ( vis[a] ) return puts ( "No" ), 0;
  31. vis[a] = true;
  32. }
  33. if ( ~b ) {
  34. if ( vis[b] ) return puts ( "No" ), 0;
  35. vis[b] = true;
  36. }
  37. }
  38. f[0] = true;
  39. for ( int i = 2; i <= n << 1; i += 2 ) {
  40. for ( int j = 0; j < i && !f[i]; j += 2 ) {
  41. f[i] = f[j] && check ( j + 1, i );
  42. }
  43. }
  44. puts ( f[n << 1] ? "Yes" : "No" );
  45. return 0;
  46. }

Solution -「ARC 104C」Fair Elevator的更多相关文章

  1. Solution -「ARC 104E」Random LIS

    \(\mathcal{Description}\)   Link.   给定整数序列 \(\{a_n\}\),对于整数序列 \(\{b_n\}\),\(b_i\) 在 \([1,a_i]\) 中等概率 ...

  2. Solution -「ARC 101D」「AT4353」Robots and Exits

    \(\mathcal{Description}\)   Link.   有 \(n\) 个小球,坐标为 \(x_{1..n}\):还有 \(m\) 个洞,坐标为 \(y_{1..m}\),保证上述坐标 ...

  3. Solution -「ARC 110D」Binomial Coefficient is Fun

    \(\mathcal{Description}\)   Link.   给定非负整数序列 \(\{a_n\}\),设 \(\{b_n\}\) 是一个非负整数序列且 \(\sum_{i=1}^nb_i\ ...

  4. Solution -「ARC 124E」Pass to Next

    \(\mathcal{Description}\)   Link.   有 \(n\) 个人站成一个环,初始时第 \(i\) 个人手里有 \(a_i\) 个球.第 \(i\) 个人可以将自己手中任意数 ...

  5. Solution -「ARC 126E」Infinite Operations

    \(\mathcal{Description}\)   Link.   给定序列 \(\{a_n\}\),定义一次操作为: 选择 \(a_i<a_j\),以及一个 \(x\in\mathbb R ...

  6. Solution -「ARC 126F」Affine Sort

    \(\mathcal{Description}\)   Link.   给定 \(\{x_n\}\),令 \[f(k)=\left|\{(a,b,c)\mid a,b\in[0,c),c\in[1,k ...

  7. Solution -「ARC 125F」Tree Degree Subset Sum

    \(\mathcal{Description}\)   Link.   给定含有 \(n\) 个结点的树,求非负整数对 \((x,y)\) 的数量,满足存在 \(\exist S\subseteq V ...

  8. Solution -「ARC 125E」Snack

    \(\mathcal{Description}\)   Link.   把 \(n\) 种零食分给 \(m\) 个人,第 \(i\) 种零食有 \(a_i\) 个:第 \(i\) 个人得到同种零食数量 ...

  9. Solution -「ARC 058C」「AT 1975」Iroha and Haiku

    \(\mathcal{Description}\)   Link.   称一个正整数序列为"俳(pái)句",当且仅当序列中存在连续一段和为 \(x\),紧接着连续一段和为 \(y ...

随机推荐

  1. centos7 修改网卡信息

    修改网卡配置文件 vim /etc/sysconfig/network-scripts/ifcfg-eth0 有一些不是eth0 也可能是ens33 修改完成后使用下面命令进行重启 systemctl ...

  2. linux光标命令快捷键(常用)

    Ctrl+a 移动到首行 Ctrl+e 移动到尾行 Ctrl+u 将当前光标后面的内容全部删除 (剪辑) ctrl+k 将当前光标前面的内容全部删除 (剪辑) Ctrl+→(左右同理) 移动到下个空格 ...

  3. Python实战案例系列(一)

    本节目录 烟草扫码数据统计 奖学金统计 实战一.烟草扫码数据统计 1. 需求分析 根据扫码信息在数据库文件中匹配相应规格详细信息,并进行个数统计 条码库.xls 扫码.xlsx 一个条码对应多个规格名 ...

  4. Spark应用的结构的学习

    关注公众号:分享电脑学习回复"百度云盘" 可以免费获取所有学习文档的代码(不定期更新) 承接上一篇文档<Standalone集群搭建和Spark应用监控> 需要了解的概 ...

  5. opencv 4.0 + linux下静态编译,展示详细ccmake的参数配置

    #先安装 cmake 3.14 # cmake安装到了 /usr/local/bin #配置PATH export PATH="$PATH:/usr/local/bin" #下载最 ...

  6. uniapp微信小程序保存base64格式图片的方法

    uniapp保存base64格式图片的方法首先第一要先获取用户的权限 saveAlbum(){//获取权限保存相册 uni.getSetting({//获取用户的当前设置 success:(res)= ...

  7. redis实现简易在线聊天室

    redis_flask简易聊天室 项目构建 这时一个基于Redis数据库的简单小项目,使用redis缓存数据,并通过flask部署到浏览器,运行截图如下: 输入名字后,就可以登陆到聊天室,主要包括三个 ...

  8. gin框架使用Air实时加载

    Air实时加载 本章我们要介绍一个神器--Air能够实时监听项目的代码文件,在代码发生变更之后自动重新编译并执行,大大提高gin框架项目的开发效率. 1.1.1. 为什么需要实时加载? 之前使用Pyt ...

  9. gin中的query和postform用法

    package main import ( "github.com/gin-gonic/gin" ) func main() { r := gin.Default() // Que ...

  10. JavaWeb后端工程师技能图