IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> APIO 2022 游记 -> 正文阅读

[数据结构与算法]APIO 2022 游记

Day -6

我以为是今天比赛,然而我发现没收到比赛邮件,然后我看了看日期,才发现原来是下周。

Day 0

在上学,根本没法上 APIO 的课。

Day 1

比赛终于开始了,然而今天要做核酸,不过还好,核酸在下午做,比赛在上午。很快就到了 9:00,比赛开始了。

T1

开幕棋盘格连通块问题,而且还是限制数据存储方式的。

题目大意: ( 2 n + 1 ) × ( 2 n + 1 ) (2n+1)\times (2n+1) (2n+1)×(2n+1) 的棋盘格中每一格只能存 100 个字节,一共遍历 n n n 轮,第 i i i 轮遍历左上角为 ( [ 1 , 2 n ? 2 k ? 1 ] , [ 1 , 2 n ? 2 k ? 1 ] ) ([1,2n-2k-1],[1,2n-2k-1]) ([1,2n?2k?1],[1,2n?2k?1]) 的大小为 3 × 3 3\times 3 3×3 的矩阵,每次只能看到矩阵内存储的信息,然后修改最左上角一格。

我在每次遍历时把整个棋盘格中下一次遍历不到的内容全都存到了角落里,直到最后一次整个棋盘格都在第一格,然后再运算得出答案,这题我得了 14 分

T2

这题的剧情好像是第一题的续集。

题目大意: 已知有 n n n 个点 m m m 条边的有向图,在动态加点的过程中求什么时候第 1 个点到第 k k k 个点中有任意一点可以成环。

我只写了 DFS 暴力,最后几分钟试图写 BFS 优化一些,结果没调试完,得了 12 分

T3

这场比赛我大部分得分都在这题,这确实是很精彩的一题。

题目大意: 构造一个任意长度的排列,使得该排列有 k k k 个上升子序列。

对于前 10 % 10\% 10% 的数据,直接从 k ? 2 k-2 k?2 写到 0 0 0 就正好有 1 个空序列和 k ? 1 k-1 k?1 个长度为 1 的子序列了。

然后,我发现了长度为 s s s 的连续上升序列的非空子序列的个数为
∑ i = 1 s C s i \sum\limits_{i=1}^s C_s^i i=1s?Csi?
又由二项式定理
( a + b ) n = ∑ i = 0 n C n i a i b n ? i (a+b)^n=\sum\limits_{i=0}^n C_n^ia^ib^{n-i} (a+b)n=i=0n?Cni?aibn?i
得出
∑ i = 1 s C s i = 2 s ? 1 \sum\limits_{i=1}^s C_s^i=2^s-1 i=1s?Csi?=2s?1
故原问题就变成了构造一个长度为 n n n 的序列 s s s,使得
k ? 1 = ∑ i = 1 n ∑ j = 1 s i C s i = ∑ i = 1 n ( 2 s i ? 1 ) = ∑ i = 1 n 2 s i ? n k-1=\sum_{i=1}^n \sum_{j=1}^{s_i}C_s^i=\sum_{i=1}^n\left(2^{s_i}-1\right)=\sum_{i=1}^n 2^{s_i}-n k?1=i=1n?j=1si??Csi?=i=1n?(2si??1)=i=1n?2si??n

∑ i = 1 n 2 s i = k + n ? 1 \sum_{i=1}^n 2^{s_i}=k+n-1 i=1n?2si?=k+n?1
我本来想的是枚举 n n n 使得 p o p c o u n t ( k + n ? 1 ) = n \mathrm{popcount}(k+n-1)=n popcount(k+n?1)=n,结果发现这样的数很难找到,于是我就改为 p o p c o u n t ( k + n ? 1 ) ≤ n \mathrm{popcount}(k+n-1)\leq n popcount(k+n?1)n,然后将位权较大的位数拆分成位权较小的位数。

然后我试着在连续的排列中交换一个元素,结果失败了。

最终得分

T1T2T3
14.0012.0063.19
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-06-01 15:26:10  更:2022-06-01 15:27:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/27 6:15:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码