P1014 [NOIP1999 普及组] Cantor 表
题目链接:https://www.luogu.com.cn/problem/P1014
有理数可枚举
In 1873 Cantor proved the rational numbers countable, i.e. they may be placed in one-one correspondence with the natural numbers.
来自:Georg Ferdinand Ludwig Philipp Cantor
1873 年,Cantor 证明了有理数是可枚举的。可枚举指的是,你可以为集合中的每个元素都分配一个唯一的自然数,建立一个一一对应的关系。
有理数具有 \(p/q\) 的形式。\(p\) 表示分母,\(q\) 表示分子,其中 \(p\) 和 \(q\) 均为正整数。
我们可以将所有有理数排列在一个表格中,其中 \(p\) 表示行,\(q\) 表示列,
{c|cccc}
p/q&1 &2 &3 &\cdots\\
\hline
1 &1/2&1/2&1/3&\cdots\\
2 &2/1&2/2&2/3&\cdots\\
3 &3/1&3/2&3/3&\cdots\\
\vdots&\vdots&\vdots&\vdots&\ddots\\
\end{array}
\]
为了对有理数进行编号,我们需要按照某种方式,将元素排成一条线。这里我们从 \(1/1\) 出发,然后移动到 \(2/1\),再往斜上方进行移动。继续按照这种方式,即,我们按照 \(\mathrm{Z}\) 型线路对沿路的元素进行编号,具体可查看下图,
图片来自:How can the set of the rational numbers be countable if there is no
通过上面的方式,我们为每个有理数都指定了一个编号,下表列出了一部分有理数和其编号,
{c|ccc}
N &1 &2 &3 &4 &\cdots\\
\hline
R&1/1 &1/2 & 2/1 &3/1&\cdots\\
\end{array}
\]
通过编号 \(N\) 获取有理数 \(R\)
哪一条对角线?
题目中我们需要通过给定的编号 \(N\),来获取对应的有理数 \(R\)。
为了获取有理数 \(R\),我们首先需要知道 \(R\) 位于第几条对角线。通过观察图片,我们发现第一条对角线上的元素个数是 \(1\),第二条对角线上的元素个数是 \(2\),按照这种方式,我们可以得知第 \(n\) 条对角线上面的元素个数是 \(n\)。我们由此可以得知前 \(n\) 条对角线的元素个数总和为 \(1+2+\cdots+n\),根据求和公式我们可得,
\]
假设编号 \(N\) 在 \(n\) 条对角线上,那么 \(N\) 满足以下的不等式
\dfrac{n(n-1)}{2} < N \leqslant \dfrac{n(n+1)}{2} \\
n^2 - n < 2N \leqslant n^2+n \\
\\\hline\\
2N \leqslant n^2 + n \\
0 \leqslant n^2 + n - 2N \\
\dfrac{-1+\sqrt{1+8N}}{2} \leqslant n \\
\\\hline\\
n^2 - n < 2N \\
n^2 - n - 2N < 0 \\
n < \dfrac{1+\sqrt{1+8N}}{2} \\
\\\hline\\
\dfrac{-1+\sqrt{1+8N}}{2} \leqslant n < \dfrac{1+\sqrt{1+8N}}{2} \\
n \in \left[\dfrac{-1+\sqrt{1+8N}}{2}, \dfrac{1+\sqrt{1+8N}}{2}\right)
\end{gather*}
\]
我们注意到 \(\left[\dfrac{-1+\sqrt{1+8N}}{2}, \dfrac{1+\sqrt{1+8N}}{2}\right)\) 的区间长度为 1。这时候,我们考虑两种情况:
- 左端点为整数。右端点此时也为整数,所以我们可知 \(n\) 的值必为左端点,即 \(n = \left\lceil\dfrac{-1+\sqrt{1+8N}}{2}\right\rceil\)。如果为右端点减去一个极小值 \(\epsilon\),再对其向下取整,我们可以得到,\(n = \left\lfloor\dfrac{1+\sqrt{1+8N}}{2}-\epsilon\right\rfloor\);
- 左端点为小数。我们可以很容易就知道 \(n = \left\lceil\dfrac{-1+\sqrt{1+8N}}{2}\right\rceil\), 右端点此时也为小数,如果为右端点减去一个极小值 \(\epsilon\)(小于左端点和左端点向下取整的差值),再对其向下取整,我们可以得到,\(n = \left\lfloor\dfrac{1+\sqrt{1+8N}}{2}-\epsilon\right\rfloor\);
现在,我们已经得到了两个公式。通过任一公式,我们都可以知道元素位于第几条对角线。
对角线上第几个元素?
下一步,我们需要知道这个元素是对角线上的第几个元素。我们已经知道这个元素位于第 \(n\) 条对角线,那么只要将编号 \(N\) 减去前 \(n-1\) 对角线包含的元素个数,就可以得出元素在对角线 \(n\) 上的位置 \(k\)。结合求和公式,我们得到,
k = N - \sum_{i=1}^{n-1} i \\
k = N - \dfrac{n(n-1)}{2}
\end{gather*}
\]
分母和分子
图片来自:How can the set of the rational numbers be countable if there is no
我们按照 \(\mathrm{Z}\) 型线路对沿路的元素进行编号,奇数对角线我们按照 \(\nearrow\) 的方向进行编号,偶数对角线我们则以 \(\swarrow\) 方向进行编号。
通过观察,我们发现同一对角线上的分母和分子之和 \(p+q\) 等于对角线编号 \(n+1\)。如果对角线方向为 \(\nearrow\),
则对角线上的第一个元素的分子为 \(1\),对角线上的第 \(k\) 个元素的分子为 \(k\);如果对角线方向为 \(\swarrow\),则对角线上的第一个元素的分母为 \(1\),对角线上的第 \(k\) 个元素的分母为 \(k\)。从而我们可以得到如下的公式,
(n+1)-k, & n \text{ 是奇数}\\
k , & n \text{ 是偶数}\\
\end{cases}
\]
(n+1)-k, & n \text{ 是偶数}\\
k , & n \text{ 是奇数}\\
\end{cases}
\]
代码
通过上面的公式,我们得到最终的代码,
// https://www.luogu.com.cn/problem/P1014
#include <iostream>
#include <cmath>
int main()
{
int N, n, k, p, q;
std::cin >> N;
n = ceil((sqrt(1+8*N)-1)/2);
/* Another way to calculate the diagonal number `n' */
// const double epsilon = 1e-9;
// n = floor((sqrt(1+8*N)+1)/2-epsilon);
k = N-n*(n-1)/2;
if (n&1)
{
p = (n+1) - k;
q = k;
}
else
{
p = k;
q = (n+1) - k;
}
std::cout << p << '/' << q << std::endl;
return 0;
}
P1014 [NOIP1999 普及组] Cantor 表的更多相关文章
- 求最长子序列(非连续)的STL方法 - 洛谷P1020 [NOIP1999 普及组] 导弹拦截
先给出例题:P1020 [NOIP1999 普及组] 导弹拦截 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 大佬题解:P1020 [NOIP1999 普及组] 导弹拦截 - 洛谷 ...
- [NOIP1999] 普及组
回文数 /*By SilverN*/ #include<algorithm> #include<iostream> #include<cstring> #inclu ...
- P1015 [NOIP1999 普及组] 回文数
点击查看题目 题目描述 若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数. 例如:给定一个十进制数 5656,将 5656 加 6565(即把 5656 从右向左读),得到 ...
- 洛谷 P1020 [NOIP1999 普及组] 导弹拦截
Coidng #include <iostream> #include <algorithm> #include <cstring> #include <ve ...
- Cantor表(NOIP1999)
题目链接:Cantor表 这道题很水,但有的人没看懂题意,这不怪大家,怪题目没说清楚. 给张图: 看到这,你应该明白题目意思了. 先看看有什么规律. 我把这个数列写出来: 1/1,1/2,2/1,3/ ...
- 洛谷——P1014 Cantor表
P1014 Cantor表 题目描述 现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1 1/2 1/3 1/4 1/5 … 2/1 ...
- 洛谷P1014 Cantor表
P1014 Cantor表 题目描述 现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1 1/2 1/3 1/4 1/5 … 2/1 ...
- 洛谷 P1014 Cantor表
P1014 Cantor表 题目描述 现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1 1/2 1/3 1/4 1/5 … 2/1 ...
- NOI / 2.1基本算法之枚举-8760:Cantor表
总时间限制: 1000ms 内存限制: 65536kB 描述 现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 我们以Z字形给上表的每一项编 ...
- 14. Cantor表
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题解 查看运行结果 题目描述 Description 现代数学的著名证明之一是Georg Cantor证明了有理数 ...
随机推荐
- Action: Consider the following: If you want an embedded database (H2, HSQL or Derby), please put it on the classpath.
错误原因 在pom中引入了mybatis-spring-boot-starter ,Spring boot默认会加载org.springframework.boot.autoconfigure.jdb ...
- Ubuntu 20.04 使用deb包安装mysql
Ubuntu 20.04 使用deb包安装mysql 1.环境 WSL2 + Ubuntu 20.04 2.下载mysql的Ubuntu / Debian安装包 MySQL :: Download M ...
- 你的梦想家居「GitHub 热点速览」
上周推荐的 ChatGPT 版小爱,不知道有哪些小伙伴回去尝试接入了呢?本周依旧由 2 个不错的 ChatGPT 延伸项目,一个是比 DeepL.Grammarly 更懂你的划词翻译 openai-t ...
- 关于两行代码让我时间无限拉长这件事------mainServlet
在再一次尝试实现增删改查的功能时,出现了一些BUG,修改功能一直实现不了,查了好久的资料,这才发现问题 如上图所示,这个Servlet里面定义的方法,虽然很短,但是重要的很奥,改了好久都没注意到这个问 ...
- LGV算法 CodeForces 348D + 牛客多校 A Monotonic Matrix
定理(Lindström–Gessel–Viennot lemma)很简单: 学的时候忘了大的行列式怎么算的了.. 然后就可以写题了: 第一道:CodeForces-348D(链接https://vj ...
- day11-MySql存储结构
MySql存储结构 参考视频:MySql存储结构 1.表空间 不同的存储引擎在磁盘文件上的结构均不一致,这里以InnoDB为例: CREATE TABLE t(id int(11)) Engine = ...
- 还在stream中使用peek?不要被这些陷阱绊住了
目录 简介 peek的定义和基本使用 peek的流式处理 Stream的懒执行策略 peek为什么只被推荐在debug中使用 peek和map的区别 总结 简介 自从JDK中引入了stream之后,仿 ...
- SpringBoot——拦截器
更多内容,前往 IT-BLOG 一.登录时可能会出现重复提交问题.我们可以通过重定向解决此问题.例如:用户提交的请求为:/user/login,通过 redirect:重定向至 main.html请求 ...
- 美团面试:熟悉哪些JVM调优参数?
本文已经收录到Github仓库,该仓库包含计算机基础.Java基础.多线程.JVM.数据库.Redis.Spring.Mybatis.SpringMVC.SpringBoot.分布式.微服务.设计模式 ...
- 升级pip报错ERROR: Could not install packages due to an OSError: [WinError 5]
今天在安装python第三方库时,提示pip需要升级,没有多想直接升级,结果报错: 1 ERROR: Could not install packages due to an OSError: [Wi ...