B. Mysterious LCM

做法

  • 保留 \(a_i|x\) 的元素,其它元素解体。
  • \(a_i\) 的某个质因子的指数,要和 \(x\) 的这个质因子一样多,才有贡献,否则这个质因子它在划水啊。
  • 那么问题转化为选出极少的数字,使得每个数字不划水的质因子并起来等于 \(x\) 的全体质因子集合。
  • 把不划水的质因子集合分类,等价于选出种类最少的集合,并出 \(x\) 质因子全集,一个优化:如果集合 B 是集合 A 的子集,集合 B 可以去除。
  • 比赛时做法不是很合理,复杂度为 \(O(\binom{c}{c/2}2^c)\),\(c\) 为 \(x\) 中质因子个数,\(dp[x][mask]\) 表示,考虑前 \(x\) 种不划水集合,能否凑出 \(mask\)。
  • 这个问题题解中讲到了两个做法。
    • 一个是 FWT,我们用 \(f[mask]\) 表示有没有不划水的质因子集合为 \(mask\),对 \(f\) 不断地做 or Convolution,直到 \(2^c-1\) 上非 0. 复杂度 \(O(c^22^c)\)
    • 另一种是 SOS DP。用 \(dp[mask]\) 表示至少需要选择几个数字,才能包含 \(mask\) 的质因子。枚举 \(mask\),枚举 \(mask\) 的拆分,\(dp[mask]=min\{dp[mask_1]+dp[mask_1\ xor\ mask]\}(mask_1 为 mask 子集)\) 就 OK 了,复杂度 \(O(3^c)\)。
  • 另一个历史遗留问题是,如何分解,质因数,统计 \(x\) 中每个质因子出现次数,wanna fly winter camp day 2 里 Tls 对这类问题有详细讲解。
    • 两种方法:一个是泼辣的肉,易解体,不推荐施展。
    • 另一个,我们需要注意到一个数字大于 1e6 的质因子不会超过 2 个,因此筛去 1e6 以下质因子后,一定是 \(1,p,pq,p^2\) 中的某种形式。
      • \(p^2\) 非常好解决,判断 sqrt 是否为整数即可。
      • 1 挂机就好,所有的质因子都已统计完毕,睡觉去。
      • \(pq\),\(p\) 很令人烦躁,纠缠在一起,难以分离,但是我们可以把 \(a_i\) 中的数字也筛去 1e6 一下的质因子,如果剩下的部分不等于 1,且不等于 x,那么剩下部分一定等于 \(p,q\) 中一种,我们就把 \(pq\) 解体了,如果剩下的部分要么等于 1,要么等于 \(x\) 那么我们可以把 \(pq\) 当成一个质因子。

C. Swipe Your Time Away

做法 预处理向上下左右各能延伸多远。

D. DarkCity, CrimsonCity ofFlightLand

做法 先预处理每条边需要多少油,dijkstra

E. Consecutive Letters

做法 先加入所有 #,然后时光倒流,还原 #,维护 # 左右连通性,以及连通块 size

F. Palindromadness

题意 对每个回文子串串求是多少回文子串的子串
做法

  • 先建PAM后统计每个回文串的出现次数
  • 对于点u,需要统计\(\sum cnt[v]\),\(v\)到\(u\)有一条经过树边或fail边的路径
  • 能否直接在\(DAG\)上解决此问题?解体
  • 观察出一个性质:如果\(u\)到\(v\)有路径,那么一定有一条路径先经过若干树边,然后经过若干条fail边到达\(v\)。
  • 所以对于一个点,只需要统计能直接或间接fail到它的所有点的子树的和就好了,这样就有了fail树上启发式合并+线段树维护回文树dfs序的做法。。。。复杂度\(O(nlog^2n)\)
  • 题解有一个更强的性质:如果\(u\)到\(v\)有路径,那么一定有一条路径先经过若干树边,然后经过最多一条fail边到达\(v\)
  • 一眼看上去这个性质肯定不对,然后发现举不出反例,然后发现一定是对的,然后感觉好牛逼
  • 这样只需要统计能直接fail到这个点的所有点的子树就行了,复杂度\(O(nlogn)\)或\(O(n)\)

G. Decode The Alien Message

做法 签到

H. Triangle Inside Rectangle Inside Pentagon

做法

  • 考虑内接的正 \(n\) 边形的边长与,正 \(n+1\) 边形边长的比例。
  • 手玩 \(n=3\)

I. Fibonacci Power Sum

做法1 求出前 100 项,吟唱BM。

做法2

  • \(f(n)^k = (f(n-1)+f(n-2))^k = \sum_{i=0}^{k} \binom{k}{i}f(n-1)^{i}f(n-2)^{k-i}\)
  • \(f(n)^{x}f(n-1)^{k-x}=(f(n-1)+f(n-2))^{x}f(n-1)^{k-x}=\sum_{i=0}^{x}\binom{x}{i}f(n-1)^{i+k-x}f(n-2)^{x-i}\)

好,线性递推来了。所以我们吟唱 BM 吧,这谁顶得住啊。

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

  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暑期集训排位(4)

    SDU暑期集训排位(4) C. Pick Your Team 题意 有 \(n\) 个人,每个人有能力值,A 和 B 轮流选人,A 先选,B 选人按照一种给出的优先级, A 可以随便选.A 想最大化己 ...

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

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

  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. js常用事件列表

    onmousedown.onmouseup 以及 onclick 事件 onmousedown, onmouseup 以及 onclick 构成了鼠标点击事件的所有部分.首先当点击鼠标按钮时,会触发 ...

  2. Go组件学习——gorm四步带你搞定DB增删改查

    1.简介 ORM Object-Relationl Mapping, 它的作用是映射数据库和对象之间的关系,方便我们在实现数据库操作的时候不用去写复杂的sql语句,把对数据库的操作上升到对于对象的操作 ...

  3. Java集合系列(四):HashMap、Hashtable、LinkedHashMap、TreeMap的使用方法及区别

    本篇博客主要讲解Map接口的4个实现类HashMap.Hashtable.LinkedHashMap.TreeMap的使用方法以及三者之间的区别. 注意:本文中代码使用的JDK版本为1.8.0_191 ...

  4. 【Java例题】7.4 文件题1-学生成绩排序

    4.学生成绩排序.已有一个学生成绩文件,含有多位学生的成绩:读取这个文件中的每位学生的成绩,然后排序:最后将这些排好序的成绩写到另一个文件中. package chapter7; import jav ...

  5. 一个基于TCP/IP的服务器与客户端通讯的小项目(超详细版)

    1.目的:实现客户端向服务器发送数据 原理: 2.建立两个控制台应用,一个为服务器,用于接收数据.一个为客户端,用于发送数据. 关键类与对应方法: 1)类IPEndPoint: 1.是抽象类EndPo ...

  6. python3学习-lxml模块

    在爬虫的学习中,我们爬取网页信息之后就是对信息项匹配,这个时候一般是使用正则.但是在使用中发现正则写的不好的时候不能精确匹配(这其实是自己的问题!)所以就找啊找.想到了可以通过标签来进行精确匹配岂不是 ...

  7. CODING 告诉你如何建立一个 Scrum 团队

    原文地址:https://www.atlassian.com/agile/scrum/roles 翻译君:CODING 敏杰小王子 Scrum 当中有三个角色:PO(product owner),敏捷 ...

  8. Sqlserver 游标的写法记录

    ---游标更新删除当前数据 ---1.声明游标 declare orderNum_03_cursor cursor scroll for select OrderId ,userId from big ...

  9. python接口测试入门1-什么是接口测试

    为什么要做接口测试 在日常开发过程中,有人做前端开发,有人负责后端开发.接口就是连接前后台,由于前端开发和后端开发的速度可能不一样,例如后端开发好了,但是前端没有开发.那么我们是不是就不需要测试呢?一 ...

  10. 小白学Python(6)——python-pptx 添加图表

    添加图表 以下代码在新演示文稿中添加单系列柱形图 from pptx import Presentation from pptx.chart.data import CategoryChartData ...