FZU Monthly-201906 tutorial
FZU Monthly-201906 tutorial
| 题目(难度递增) | easy | easy-medium | medium | medium-hard | hard |
|---|---|---|---|---|---|
| 思维难度 | AE | B | DG | CF | H |
A. Xorisk
求出前缀异或和。从头到尾扫一遍,维护map[x]表示之前有多少个前缀异或和为x,枚举到第i个数就加上map[ai^k]即可。
B. short-path-problem
裸的最短路,构造数据卡掉了SPFA写法,使用Dijkstra就可以正常AC。
C. cover
可以先把字符串插入AC自动机里,用dp来计数,状态表示为f[i][j][k],表示长度为i,现在在自动机状态为j,而且已经有长度为k没被覆盖了,转移就是枚举4个字符,转移一下自动机状态和没被覆盖的长度
D. banzhuan
题意
三维空间一块方形空间,要摆一些实心格子,每个格子有个代价,这格子可以摆当且仅当下面是地面或者下面的格子已经摆了,求最大代价最小代价
题解: 贪心+数学
这个题目,出题组搞出了个假的贪心策略,也就是说标程写了个假算法,特在此致歉,不知道在考试期间,有没有给选手们带来困扰或者不必要的麻烦,但是大部分选手这题都没有提交,不知道是否是时间安排不当,这个题目定位是个仅次于签到的贪心难度,虽然纠正之后的贪心难度,要比之前的稍微难一些,但是贪心策略是不难想到的,选手们应该要有尝试;经过后来补充测试,本场冠军的这道题在倒数第二发通过了,时间离结束也不远
另一方面,本题题面还有点小歧义,虽然按照正常一些的理解,是符合出题人的设定的,但是没有严格明确强调,主要是中文题面,里面有个字“放”,有点语义上的歧义,比如可以理解为放这个动作,也可以理解为放着这种状态
显然最底下一层要铺满,考虑上面的任意一层,如果你把贡献的\(z\)这个因子,提取出来,那么容易发现这个一层就转化为一个平面的问题了,因为剩余的因子大家是一样的
考虑一层如何摆布才能最小:
1)考虑最优的方案中,2-n这些列显然不会同一列出现两个;如若不然,设有两个棋子,上面这个设为\(A\),下面设为\(B\),可以把\(A\)移动到第一列,这样显然效果更好,且代价更低,故由调整法可证2-n这些列最多一个棋子,且每列至少一个,故每列严格一个棋子

2)2-n每一列的棋子一定放在第1行,反证法,如若不然,将一个棋子\(C\)拆分为两个棋子\(C1\)和\(C2\),如图:
\[
xy^2-(x1^2+1y^2)=xy^2-x-y^2+1-1=(x-1)(y^2-1)-1 \ge 2 \gt 0,\forall x \ge 2,y \ge2
\]
故由调整法知2-n的棋子严格放在第1行

3)2-n行每行只会放一个棋子,且放在第一列,且\((1,1)\)不放棋子,显然

最优排布一层的就是这样,红色部分为棋子
现在考虑很多层,假设前\(k\)层已经都排布好了,现在放第\(k+1\)层,因为第\(k+1\)层这样放是最优的,且恰好可以放在第\(k\)层上,由归纳法知就这样放满\(n\)层就是可行且最优的方案
最大值显然就是全部排满\(n^3\),只要计算一下答案即可
\[
ret_{max}=(\sum_{z=1}^nz)(\sum_{x=1}^nx)(\sum_{y=1}^ny^2) \\
ret_{min}=(\sum_{x=1}^nx)(\sum_{y=1}^ny^2)+\sum_{z=2}^nz(\sum_{x=2}^nx+\sum_{y=2}^ny^2)
\]
E. spanning-tree
题意
问1到n这些数,构成完全图,w(i,j)=i+j,次小生成树
题解
很简单的贪心,就所有点都连1,这样就是最小的,然后把3连1改成3连2即可,就是次小的了(比最小的多1)
证明:
首先,最小生成树严格有\(n-1\)条边,\(2n-2\)个度之和,那么答案显然为\(2n-2\)的正整数之和\(S=\sum_{i=1}^na_i\)
最小生成树要联通,即每个点至少一个度,那么其中\(n\)个数固定为\(1,2,3\dots n\)
剩下的\(n-2\)个数,显然至少为\(1\),那么\(S \ge n-2 +\sum_{i=1}^ni=n(n+1)/2+n-2\)
前面我们显然找到了一种构造方案,使得上式取到等号
F. 8862015
数位DP中的基础题
G. Euclid
可以发现两个式子可以拼成一个矩形内整点数量,所以答案是(p - 1) * (q - 1) /4,注意p和q相等时拼的线要多算一次,所以还要加 (p - 1) / 2.
H. i-love-gcd
题意与题解
本题留有空白,给选手们自己思考,考点和算法方向也隐藏
FZU Monthly-201906 tutorial的更多相关文章
- FZU Monthly-201903 tutorial
FZU Monthly-201903 tutorial 题目(难度递增) easy easy-medium medium medium-hard hard 思维难度 ABF G CH D E A. D ...
- FZU Monthly-201901 tutorial
FZU Monthly-201901 tutorial 题目(难度递增) easy easy-medium medium medium-hard hard 思维难度 AHG F B CE D 编码难度 ...
- FZU Monthly-201909 tutorial
FZU Monthly-201909 tutorial 题目(难度递增) easy easy-medium medium medium-hard hard 思维难度 AB CD EF G H A. I ...
- FZU Monthly-201905 tutorial
FZU Monthly-201905 tutorial 题目(难度递增) easy easy-medium medium medium-hard hard 思维难度 AB H DG CE F A. C ...
- Microsoft Azure Tutorial: Build your first movie inventory web app with just a few lines of code
Editor’s Note: The following is a guest post from Mustafa Mahmutović, a Microsoft Student Partner wh ...
- Career Planning:Developers Best Practices Tutorial
This small tutorial is based on my past 16+ years of experience in software development industry. I ...
- [翻译+山寨]Hangfire Highlighter Tutorial
前言 Hangfire是一个开源且商业免费使用的工具函数库.可以让你非常容易地在ASP.NET应用(也可以不在ASP.NET应用)中执行多种类型的后台任务,而无需自行定制开发和管理基于Windows ...
- Monthly Income Report – August 2016
原文链接:https://marcoschwartz.com/monthly-income-report-august-2016/ Every month, I publish a report of ...
- Django 1.7 Tutorial 学习笔记
官方教程在这里 : Here 写在前面的废话:)) 以前学习新东西,第一想到的是找本入门教程,按照书上做一遍.现在看了各种网上的入门教程后,我觉得还是看官方Tutorial靠谱.书的弊端一说一大推 本 ...
随机推荐
- JavaScript---Bom树的操作,内置方法和内置对象(window对象,location对象,navigator对象,history对象,screen对象)
JavaScript---Bom树的操作,内置方法和内置对象(window对象,location对象,navigator对象,history对象,screen对象) 一丶什么是BOM B ...
- 使用 Go 语言徒手撸一个负载均衡器
负载均衡器在 Web 架构中扮演着非常重要的角色,被用于为多个后端分发流量负载,提升服务的伸缩性.负载均衡器后面配置了多个服务,在某个服务发生故障时,负载均衡器可以很快地选择另一个可用的服务,所以整体 ...
- 学习笔记之正则表达式 (Regular Expressions)
正则表达式_百度百科 http://baike.baidu.com/link?url=ybgDrN2WQQKN64_gu-diCqdeDqL8LQ-jiQ-ftzzPaNUa9CmgBRDNnyx50 ...
- 【总结】web工作代码分类整理(持续更新)
文件.blob 文件下载失败,将Blob对象转换为Json,处理异常错误? 使用FileReader,核心代码: var reader = new FileReader() reader.onload ...
- 排序算法的c++实现——插入排序
插入排序的思想是:给定一个待排序的数组,我们从中选择第一个元素作为有序的基态(单个元素肯定是有序的), 然后从剩余的元素中选择一个插入到有序的基态中,使插入之后的序列也是有序状态,重复此过程,直到全部 ...
- springboot异常处理方式
一.异常处理思路 异常捕获的是unchecked型异常,因为checked异常在代码中年已经处理过,当然是在使用try-catch处理.这里首先使用ExceptionHandler捕获全局异常,这样如 ...
- prometheus学习系列二: Prometheus安装
下载 在prometheus的官网的download页面,可以找到prometheus的下载二进制包. [root@node00 src]# cd /usr/src/ [root@node00 src ...
- 攻防世界WEB高手进阶之blgdel
CISCN final 打开页面 扫描目录 Robots.txt Config.txt 代码审计 <?php class master { private $path; private $nam ...
- Huffman Tree (哈夫曼树学习)
WPL 和哈夫曼树 哈夫曼树,又称最优二叉树,是一棵带权值路径长度(WPL,Weighted Path Length of Tree)最短的树,权值较大的节点离根更近. 首先介绍一下什么是 WPL,其 ...
- 打造好用的C++ IDE环境
https://www.jianshu.com/p/1aa989808e15 这哥们说的也是极好,也可以这部分直接看他的示例! mingw-w64应该可以算是mingw的改进版本吧,mingw系列编译 ...