Codechef April Challenge 2019 游记
Codechef April Challenge 2019 游记
Subtree Removal
题目大意:
一棵\(n(n\le10^5)\)个结点的有根树,每个结点有一个权值\(w_i(|w_i\le10^9|)\)。你可以进行若干次(包括\(0\)次)操作,每次你可以选择一个连通块,将其删去。若你的操作次数为\(k\),则总收益为剩下结点权值之和\(-X\cdot k\)。求最大总收益。
思路:
树形DP,\(f_x\)表示以\(x\)为根的子树的最大总收益。转移时\(f_x=w_x+\sum_{y\in{\rm children}_x}f_y\)。若\(f_x<-X\),则令\(f_x=-X\)。
时间复杂度\(\mathcal O(n)\)。
源代码见提交记录。
Playing with Numbers
题目大意:
一棵\(n(n\le10^5)\)个结点的有根树,每个结点有一个权值\(v_i\)和一个额外的属性\(m_i\)。对于一个叶子结点\(l_i\),定义其答案为:
- 对于从根节点到\(l_i\)的路径上的每个节点,选择一个非负整数,乘以节点的点权。
- 对路径上所有节点按照上述方式算出来的值求和。
- 叶子\(l_i\)的答案就是和对\(m_{l_i}\)取模的最大值。
求每个叶子节点的答案。
思路:
一个结论是,若干个数\(\{A_1,A_2,\ldots,A_k\}\)在模\(m\)意义下,能组合出的最大数为\(m-\gcd(A_1,A_2,\ldots,A_k,m)\)。
只需一次DFS求出\(l_i\)到根结点链上的\(\gcd\),然后套用上述结论即可。
时间复杂度\(\mathcal O(n\log v_i)\)。
源代码见提交记录。
Kira Loves Palindromes
题目大意:
给定字符串\(S(|S|\le1000,S_i\in[\texttt{'a'},\texttt{'z'}])\),请求出有多少种方案可以从该字符串中选出两个不相交的非空子串(记为\(s_1\)和\(s_2\)),使得其串接\(s_1+s_2\)为回文串。
我们认为\((s_1,s_2)\)和\((s^′_1,s^′_2)\)是不同的两种方案,当且仅当\(s_1\)和\(s^′_1\)的位置不同,或者\(s_2\)和\(s^′_2\)的位置不同。
思路:
如图所示:
\(s_1=\texttt{'abc'},s_2=\texttt{'xyxcba'}\),其中\(\texttt{'abc'}\)和\(\texttt{'cba'}\)是对应的部分,而\(\texttt{'xyx'}\)是插入在中间的回文串。
枚举两个\(\texttt{'c'}\)的位置\(p\)和\(q\),二分出从\(p\)和\(q\)往两侧扩展出的最长距离\(len\),对于插入串\(S_{[l,r]}\),预处理出满足\(l=p+1\)且\(r<q-1\)或\(r=q-1\)且\(l>p+1\)的回文串个数\(cnt\)(注意这里不考虑\(l=p+1\)且\(r=q-1\)的情况,避免算重)。对于固定的\(p,q\),答案为\(len\times(cnt+1)\)(\(+1\)表示插入串为空)。最后将未统计的\(l=p+1\)且\(r=q-1\)的情况计入答案即可。
使用字符串哈希算法可以简单地实现。
时间复杂度\(\mathcal O(n^2\log n)\)。
源代码见提交记录。
Offer for Chef
题目大意:
一个长度为\(n(n\le10^5)\)的数列\(A_{1\sim n}\),\(q(q\le10)\)次询问,每次给出数列\(t_{1\sim n}\)(\(t_i\)中只有不超过\(50\)个数不为\(0\))和一个整数\(k\),问将这个数列分为\(k\)段,定义每一段的价值为区间内每个元素\(A_i\cdot t_i\)之和。总收益为所有区间价值的按位与。最大化总收益。
思路:
原题链接CF981D。
显然我们可以将\(A_i\cdot t_i=0\)的数去掉,记剩下数的个数为\(m\)。
从高到低枚举答案的每一个二进制位,判断是否可以为\(1\)。若可以,则在保留这一位的情况下处理下一位。判定某一位是否能为\(1\)可以用一个\(\mathcal O(m^3)\)的动态规划实现,这里不再赘述。
大约枚举\(60\)个二进制位,时间复杂度\(\mathcal O(60\cdot qm^3)\)。
源代码见提交记录。
Mininum XOR over Tree
题目大意:
给定一棵\(n(n\le2\times10^5)\)的有根树,每个结点有权值\(w_i(1\le w_i<2^20)\)。\(q(q\le10^6)\)次询问,给定结点\(v\)和参数\(k(q\le k<2^20)\),求对于子树\(v\)中所有结点\(u\),\(w_u\oplus k\)的最大值,并输出使答案最大的编号最小的\(u\)。强制在线。
思路:
以DFS序为时间,建立可持久化01字典树。查询时就在子树对应的区间内查找能异或出的最大值。
考虑如何根据这个\(w_u\oplus k\)的最大值求出最小的\(u\)。
将所有结点以\(w_i\)为第一关键字,DFS序为第二关键字排序。维护区间内结点编号的最小值。询问时由于知道了\(w_u\),只须在对应权值、对应DFS序的区间内查找最大值即可。这可以用稀疏表方便地实现。
时间复杂度\(\mathcal O(n\log n+(n+q)\log w_i)\)。
实现上需要注意常数。
源代码见提交记录。
Codechef April Challenge 2019 游记的更多相关文章
- CodeChef April Challenge 2019题解
传送门 \(Maximum\ Remaining\) 对于两个数\(a,b\),如果\(a=b\)没贡献,所以不妨假设\(a<b\),有\(a\%b=a\),而\(b\%a<a\).综上, ...
- Codechef April Challenge 2019 Division 2
Maximum Remaining 题意:给n个数,取出两个数$a_{i}$,$a_{j}$,求$a_{i}\% a_{j}$取模的最大值 直接排个序,第二大(严格的第二大)模第一大就是答案了. #i ...
- Codechef October Challenge 2018 游记
Codechef October Challenge 2018 游记 CHSERVE - Chef and Serves 题目大意: 乒乓球比赛中,双方每累计得两分就会交换一次发球权. 不过,大厨和小 ...
- Codechef September Challenge 2018 游记
Codechef September Challenge 2018 游记 Magician versus Chef 题目大意: 有一排\(n(n\le10^5)\)个格子,一开始硬币在第\(x\)个格 ...
- Codechef November Challenge 2019 Division 1
Preface 这场CC好难的说,后面的都不会做QAQ 还因为不会三进制位运算卷积被曲明姐姐欺负了,我真是太菜了QAQ PS:最后还是狗上了六星的说,期待两(三)场之内可以上七星 Physical E ...
- Codechef October Challenge 2019 Division 1
Preface 这次CC难度较上两场升高了许多,后面两题都只能借着曲明姐姐和jz姐姐的仙气来做 值得一提的是原来的F大概需要大力分类讨论,结果我写了一大半题目就因为原题被ban了233 最后勉强涨了近 ...
- Codechef September Challenge 2019 Division 2
Preface 这确实应该是我打过的比较水的CC了(其实就打过两场) 但由于我太弱了打的都是Div2,所以会认为上一场更简单,其实上一场Div的数据结构是真的毒 好了废话不多说快速地讲一下 A Eas ...
- Codechef August Challenge 2019 Division 2
Preface 老年菜鸡终于开始打CC了,由于他太弱了所以只能打Div2 因为台风的原因challenge并没有写,所以水了个Rank7 A Football SB模拟题不解释 #include< ...
- 【Code Chef】April Challenge 2019
Subtree Removal 很显然不可能选择砍掉一对有祖先关系的子树.令$f_i$表示$i$子树的答案,如果$i$不被砍,那就是$a_i + \sum\limits_j f_j$:如果$i$被砍, ...
随机推荐
- react 中使用阿里彩色图标
1. 不光要引入css ,还要引入js 2. 在需要引入icon的地方添加 <svg className={styles.menuIcon} aria-hidden="true&quo ...
- windows安装解压版mysql
记录下用批处理安装mysql5.7.18的过程与踩到的坑 先在安装目录新建文件my.ini [mysql] default-character-set=utf8 basedir=TODO datadi ...
- day04 流程控制
在python中流程控制主要有三种:顺序流程.分支流程.循环流程 1.顺序流程:在宏观上,python程序的运行就是自上而下的顺序流程: 2.分支流程:分支流程主要是 if...else....流程 ...
- nyoj 633 幂
幂 nyoj 633 应用数学 幂 时间限制:3000 ms | 内存限制:65535 KB 描述 在学习循环的时候,我们都练习过利用循环计算a的k次方.现在给定整数k和一个整数m,请你求出对 ...
- SQL Server 数据库限制单用户使用和解除单用户使用
一个在单用户(SINGLE_USER)模式下的数据库一次只能有一个连接.在限制用户(RESTRICTED_USER)模式下的数据库只能接受被认为是“合格”用户的连接——这些用户属于dbcreator或 ...
- python获取设备主机名和IP地址
import socket def print_machine_info(): host_name = socket.gethostname() ip_address = socket.gethost ...
- matlab读取图片的异常表现
在对人脸图片进行对齐时,发现有两张人脸图片一直检测不到人脸,但这两张图片中的人脸明明很好检测(证件照),经过 排查,最终发现问题所在:图片的格式不对. img = imread("**.jp ...
- C# 高级编程02----手动创建C#程序
在日常工作中使用C# 开发的时候,通常使用宇宙第一神器VS进行开发.为了了解编译过程,这里采用文本编辑器的方式编写一个C#程序 一.创建一个C#程序 1.使用记事本工具创建一个名为First.cs的文 ...
- MapReduce流量统计
准备数据access.log 要用到的只有第二个手机号,倒数第三上行流量,倒数第二下行流量. 1363157985066 13726230503 00-FD-07-A4-72-B8:CMCC 120. ...
- 怎样解决if __name__ == "__main__":下面的代码没有执行的问题
很多初学者可能在用pycharm运行代码时会出现if __name__ == "__main__":下面的代码没有执行的问题,出现这类问题的原因是unittest运行姿势造成的,如 ...