SDU暑期集训排位(4)


C. Pick Your Team

题意 有 \(n\) 个人,每个人有能力值,A 和 B 轮流选人,A 先选,B 选人按照一种给出的优先级,
A 可以随便选。A 想最大化己方能力值。

做法

  • 划分方案合法的充要条件:任何前缀中,\(被 B 选择的人 - 被 A 选择的人 > -1\)
  • 考虑 DP,\(dp[i][j]\) 表示考虑前 \(i\) 个人,\(j\) 个人被 B 选择了,A 和 B 最大分差。
  • 考虑转移,枚举 \(i+1\) 个人归属即可。

D. Piece of Cake

题意 一个凸多边形上随机选k个顶点,求构成的凸多边形的面积的期望
做法

  • 看成总面积减去一些由连续的几个点组成的多边形的面积
  • 由x个点组成的多边形被减去的概率为\(\frac{C_{n-x}^{k-2}}{C_n^k}\)
  • 这个概率要先约一约再算,而且要乘除交替计算,否则会爆精度
  • 没注意复杂度T两发实属智障

E.Busy Board

题意

做法

各种特判套在一起就行了,无法用语言描述


F. It's a Mod, Mod, Mod, Mod World

题意 求 \(\sum_{i=1}^{n}[pi\%q]\)

做法

  • GCD 的经典应用。
  • \(\sum_{i=1}^{n}[pi\%q] = \sum_{i=1}^{n} (pi-[\frac{pi}{q}]q)=(\sum_{i=1}^{n}pi)-q(\sum_{i=1}^{n}[\frac{pi}{q}])\)
  • 只需求 \(f(n,p,q)=\sum_{i=1}^{n}[\frac{pi}{q}]\)
  • 若 \(p\geq q\) 可递归到 \(f(n,p\%q,q)\)
  • 若 \(p<q\) 可枚举 \(x\),统计 \([\frac{pi}{q}]\geq x\) 的 \(i\) 方案数,即可交换 \(p,q\)
  • 更详细介绍见2009年论文 金斌《欧几里得算法的应用》

G.Monotony

题意 给定一个矩阵,问其有多少个子矩阵满足行列单调性

题解

  • 枚举选哪些行
  • 特判哪些列在选了这些行之后是合法的
  • 考虑到,只选两列就能确定行的单调性,所以可以\(DP\)
  • \(DP[mask][j]\) : 选了第\(j\)列,并且行的单调性为\(mask\)的方案数
  • 然后枚举下一个\(k\),往后转移即可

I.Intersecting Rectangles

题意 给定n个矩形,问是否有交

做法

  • 扫描线
  • 从小到大枚举横坐标,如果是矩形左边界,查询上下边界内是否有点被标记,有的话直接输出yes,否则把上下边界打上标记,如果是右边界,消去边界
  • 然后交换x,y坐标,再来一次

J. Cutting Strings

upsolved

题意 给一个字符串,可以截取下 \(k\) 段,使得字典序最大。

做法

  • idea 比较简单,逐位考虑,我们先想让 'z' 字符的前缀尽可能长,以此为前提接下来想让之后的 'y' 尽可能长........
  • 递归地求解 \(solve(pos,k,ch)\),在 \(suffix(pos)\) 中,我们想构造尽可能长的 ch 前缀,至多可以切 \(k\) 刀。
    • 如果 s[pos] = ch,第一段连续的 ch 一定可以拿,我们可以递归到 \(solve(nex,k,ch)\),\(nex\) 为下一个不为 ch 的位置。
    • 否则,考虑连续的 ch 的段,设这些段分别为 \([l_1,r_1],[l_2,r_2]....[l_m,r_m]\)
      • 如果 \(k \geq m\),那么这些 \(suffix(pos)\) 中所有的 \(ch\) 都可以加入到答案中,递归到 \(solve(r_m + 1, k-m, ch-1)\)
      • 否则,我们可以在这 \(m\) 段中,枚举最后一个区间的位置,堆维护前 \(k-1\) 大值,再枚举最后一个区间的位置,在可能成为答案的后缀中挑选字典序最大的即可。

code


K. Subsequences in Substrings

做法 序列自动机,预处理位置 \(x\) 下一个字符 \(ch\) 在哪,枚举起点,然后往后跳。复杂度 \(O(|S|*|T|)\)


M. XOR Sequences

upsolved
题意 给定\(p_0,p_1,...,p_{2^m-1}\)求有多少长度为n的序列\({x}\)满足\(p_i=argmax\ i⊕x_j\)
做法

  • 考虑从顶向下建x的trie树
  • 对于当前点,如果左树和右树的每个元素对应相等,那么只有左儿子或者只有右儿子,答案乘2,然后递归建左儿子或右儿子
  • 不是对应相等的话说明既有左儿子又有右儿子,需要左树和右树的元素没有交集,然后递归建左儿子和右儿子
  • 此题原榜过穿了,是个简单题,就是看起来很吓人
  • 当时一看就没思路,其实算下样例也就会了

SDU暑期集训排位(4)的更多相关文章

  1. SDU暑期集训排位(9)

    SDU暑期集训排位(9) G. Just Some Permutations 基础 DP 练习部分 定义 \(f(S)\),表示让 S 中的人全 happy 的方案数. \(dp[i][j]\) 表示 ...

  2. SDU暑期集训排位(5)

    SDU暑期集训排位(5) A. You're in the Army Now 题意 类似选志愿.每个人有 mark,有优先级从高到低的志愿. 做法 定睛一看,鲨鼻题.然后 WA. 为什么会 WA 呢? ...

  3. SDU暑期集训排位(8)

    A. A Giveaway 签到 B. Game of XOR 做法 dp[G][L][R]表示在倒数第G代,左边的数是L,右边的数是R,下面共有多少个0和1 区间和转换成两次前缀和和一次单点查询 利 ...

  4. SDU暑期集训排位(3)

    B. Mysterious LCM 做法 保留 \(a_i|x\) 的元素,其它元素解体. \(a_i\) 的某个质因子的指数,要和 \(x\) 的这个质因子一样多,才有贡献,否则这个质因子它在划水啊 ...

  5. SDU暑期集训排位(2)

    A. Art solved by sdcgvhgj 3min 签到 B. Biology solved by sdcgvhgj 85min 暴力 C - Computer Science solved ...

  6. 2014年CCNU-ACM暑期集训总结

    2014年CCNU-ACM暑期集训总结 那个本期待已久的暑期集训居然就这种.溜走了.让自己有点措手不及.很多其它的是对自己的疑问.自己是否能在ACM这个领域有所成就.带着这个疑问,先对这个暑假做个总结 ...

  7. 8.10 正睿暑期集训营 Day7

    目录 2018.8.10 正睿暑期集训营 Day7 总结 A 花园(思路) B 归来(Tarjan 拓扑) C 机场(凸函数 点分治) 考试代码 A B C 2018.8.10 正睿暑期集训营 Day ...

  8. 8.6 正睿暑期集训营 Day3

    目录 2018.8.6 正睿暑期集训营 Day3 A 亵渎(DP) B 绕口令(KMP) C 最远点(LCT) 考试代码 A B C 2018.8.6 正睿暑期集训营 Day3 时间:5h(实际) 期 ...

  9. 8.9 正睿暑期集训营 Day6

    目录 2018.8.9 正睿暑期集训营 Day6 A 萌新拆塔(状压DP) B 奇迹暖暖 C 风花雪月(DP) 考试代码 A B C 2018.8.9 正睿暑期集训营 Day6 时间:2.5h(实际) ...

随机推荐

  1. Docker 安装部署Sql Server

    前言 在如今,容器化概念越来越盛行,.Net Core项目也可以跨平台部署了,那么思考下Sql Server能不能呢?当然是可以的啦.本文今天就是介绍Docker部署配置和连接Sql Server.本 ...

  2. 精准营销、批量提取QQ群成员号码

    有时我们在做精准营销时,需要从社群里提取群成员的QQ号,群发邮件,常规的做法是手工一个个复制粘贴,这样的效率无疑是很低的,下面我来分享一个批量获取社群的QQ号方法. 需要具备以下工具: 1.大量精准Q ...

  3. Java----面向对象(继承&多态)

    一.继承 什么是继承 ? 让类与类之间产生了子父类关系 ; 继承的好处是: 提高代码的复用性和维护性 java中继承的特点是: 只支持单继承.不支持多继承,但是可以多层继承; 四种权限修饰符是 : p ...

  4. kubernetes离线包分析

    k8s离线包解析 产品地址 鸣谢 大家好,首先感谢大家对我们产品的支持,特别是一些老客户的持续支持,让我可以有动力把这个事情持续进行下去. 感谢大家对付费产品的认可,尊重付费 产品介绍 我们专注于k8 ...

  5. Linux下SVN库迁移

    在日常的工作中,可能因为一些服务器硬件损坏等问题,不得不把SVN服务器上的SVN版本库进行迁移,下面讲解一下SVN库迁移方案(采用dump & load方案),在实际操作的时候也非常的简单,有 ...

  6. 一文了解:Redis的AOF持久化

    Redis的AOF持久化 每当Redis-Server接收到写数据时,就把命令以文本形式追加到AOF文件里,当重启Redis服务时,AOF文件里的命令会被重新执行一次,重新恢复数据.当AOF过大时将重 ...

  7. 关于Linux安装的Python和miniconda

    ///注意 开头全部是小写建议自己手敲代码不要拷贝 1. Linux下软件的安装: a) Yum 安装(工具) rpm的增强版 b) Rpm安装 c) 源码编译安装:python3(LAMP) d) ...

  8. DRF (Django REST framework) 中的视图类

    视图说明 1. 两个基类 1)APIView rest_framework.views.APIView APIView是REST framework提供的所有视图的基类,继承自Django的View父 ...

  9. 开源题材征集 + MVC&EF Core 完整教程小结

    到目前为止,我们的MVC+EF Core 完整教程的理论部分就全部结束了,共20篇,覆盖了核心的主要知识点. 下一阶段是实战部分,我们将会把这些知识点串联起来,用10篇(天)来完成一个开源项目. 现向 ...

  10. 「雕爷学编程」Arduino动手做(15)——手指侦测心跳模块

    37款传感器和模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器与模块,依照实践出真知(动手试试)的理念,以学习和交流为目的,这里准备 ...