FJOI2017前做题记录

2017-04-15

[ZJOI2017] 树状数组 问题转化后,变成区间随机将一个数异或一,询问两个位置的值相等的概率。(注意特判询问有一个区间的左端点为1的情况,因为题目要求,所以这种情况要特殊考虑)考虑一个修改操作对一个询问的影响,分为以下几类:

(1) 区间不包含任何一个点,这种情况对答案没有影响。

(2) 区间只包含其中一个点,这种情况有\(1/len\)的概率影响答案

(3) 区间同时包含两个点,这种情况有\(2/len\)的概率影响答案。

这个时候我们把线段的左右端点看做两维,操作时间看做第三维,然后这个时候原问题就变成了三维偏序问题。用树套树或cdq分治+线段树来解决即可。(我写的是cdq分治套线段树)。

2017-04-16

AtCoder Grand Contest 013 A B C 一场非常失败的\(AGC\),整场就过了第一题(还WA了三发)。。。

A题问一个数组最少能被划分成多少个权值单调不增或不减的区间。刚开始懒得写贪心,然后就找性质,发现只和波峰和波谷的数量有关。然后写一发样例就不过了。(相邻的波峰和波谷选一个就可以了)然后强行判过样例交上去WA。很着急啊,然后发现有可能波峰或波谷是一段平的。于是就直接unique掉然后交。又WA。发现unique我打的是unique(a+1,a+n)。。。感觉整个人傻逼了。改完a。

B题题目看很久+想复杂了。找一个路径使得和路径的头尾相连的点都在路径中。题目叫哈密顿路径然后我就真的往那边去想了QAQ,结果就掉坑了(果然题目里的算法都不能信)。。。正解是直接用deque去扩展,扩展到不能扩展位置。(其实这个思路有在我脑袋里闪过,结果不知道怎么搞deque就弃了)

C题思维题啊。在刘汝佳的白书上有这道题,就是蚂蚁撞来撞去那道。我的思维卡在如何找到某一个数的位置上然后未果。看了题解还是不懂。最后强行看别人Code去理解。考虑以下几个性质(这几个性质白书上也有):

  1. 两个蚂蚁相撞以后会头可以看做他们继续前进,然后交换他们\(id\) 。
  2. 任何时候所有蚂蚁的相对位置不会发生改变。
  3. 所有蚂蚁的最终位置可以直接加上/减去t来确定。

由2 3 可得,最终蚂蚁的位置是通过对所有蚂蚁的终态排序得到的。也就是说我们只要知道第一个蚂蚁的位置就知道了所有其他蚂蚁的位置。

如何求得第一个蚂蚁的位置是本题的关键(也是我考场上不会做的关键QAQ)。一个思路是考虑在什么时候整个序列的绝对位置会发生变化。我们发现,这个时候就是有一个蚂蚁跨过0这个位置的时候。如果这个蚂蚁跨过0以后顺时针移动,那么相当于整个排名右移一位,并且把最后一位放到了第一位。逆时针就相反。所以我们就记录一下绝对排名的偏移量,最后输出时第一个蚂蚁的位置就是这个偏移量。

2017-04-17

[Sdoi2017]d1t3 矩阵快速幂(性质:循环矩阵)

2017-04-18

[Sdoi2017]d1t1 莫比乌斯反演

2017-04-19

【UER#6】抓捕罪犯 2-SAT

2017-04-20

[Sdoi2017]d2t1 分数规划+费用流

[Ynoi2017]d1t1 莫队+bitset

2017-04-21

3489: A simple rmq problem 可持久化树套树

[Ynoi2017]d1t2 树链剖分套线段树、位运算相关、贪心

2409: 地下车会 上下界的最大流

3876: [Ahoi2014]支线剧情 上下界费用流

2521: [Shoi2010]最小生成树 最小生成树->联通关系->最小割->最大流

2017-04-22

4570: [Scoi2016]妖怪 凸包。注意点:不仅仅是最优斜率要统计答案,对于凸包上的边也要统计答案。

4817: [Sdoi2017]树点涂色 lct+线段树。注意:lct上的父亲并不是原树上的父亲!

FJOI2017前做题记录的更多相关文章

  1. NOIP前做题记录

    鉴于某些原因(主要是懒)就不一题一题写了,代码直接去\(OJ\)上看吧 CodeChef Making Change 传送门 完全没看懂题解在讲什么(一定是因为题解公式打崩的原因才不是曲明英语太差呢- ...

  2. Sam做题记录

    Sam做题记录 Hihocoder 后缀自动机二·重复旋律5 求一个串中本质不同的子串数 显然,答案是 \(\sum len[i]-len[fa[i]]\) Hihocoder 后缀自动机三·重复旋律 ...

  3. UOJ 做题记录

    UOJ 做题记录 其实我这么弱> >根本不会做题呢> > #21. [UR #1]缩进优化 其实想想还是一道非常丝播的题目呢> > 直接对于每个缩进长度统计一遍就好 ...

  4. project euler做题记录

    ProjectEuler_做题记录 简单记录一下. problem 441 The inverse summation of coprime couples 神仙题.考虑答案为: \[\begin{a ...

  5. 退役IV次后做题记录

    退役IV次后做题记录 我啥都不会了.... AGC023 D 如果所有的楼房都在\(S\)同一边可以直接得出答案. 否则考虑最左最右两边的票数,如果左边>=右边,那么最右边会投给左边,因为就算车 ...

  6. 退役III次后做题记录(扯淡)

    退役III次后做题记录(扯淡) CF607E Cross Sum 计算几何屎题 直接二分一下,算出每条线的位置然后算 注意相对位置这个不能先搞出坐标,直接算角度就行了,不然会卡精度/px flag:计 ...

  7. 退役II次后做题记录

    退役II次后做题记录 感觉没啥好更的,咕. atcoder1219 历史研究 回滚莫队. [六省联考2017]组合数问题 我是傻逼 按照组合意义等价于\(nk\)个物品,选的物品\(\mod k\) ...

  8. BJOI做题记录

    BJOI做题记录 终于想起还要做一下历年省选题了2333 然而咕了的还是比做了的多2333 LOJ #2178. 「BJOI2017」机动训练 咕了. LOJ #2179. 「BJOI2017」树的难 ...

  9. [日记&做题记录]-Noip2016提高组复赛 倒数十天

    写这篇博客的时候有点激动 为了让自己不颓 还是写写日记 存存模板 Nov.8 2016 今天早上买了两个蛋挞 吃了一个 然后就做数论(前天晚上还是想放弃数论 但是昨天被数论虐了 woc noip模拟赛 ...

随机推荐

  1. Vue 2019开发者图谱

    作为 Vue 的初学者,您或许已经听过很多关于它的专业术语了,例如:单页面应用程序.异步组件.服务器端呈现等,您可能还听过和Vue经常一起被提到的工具和库,如Vuex.Webpack.Vue CLI和 ...

  2. Codeforces 1209D Cow and Snacks

    题目大意 有 $n$ 个不同的糖果,从 $1$ 到 $n$ 编号.有 $k$ 个客人.要用糖果招待客人. 对于每个客人,这些糖果中恰有两个是其最爱.第 $i$ 个客人最爱的糖果编号是 $x_i$ 和 ...

  3. Java代码 简单用于处理和数据库相关的操作

    package util; import org.apache.commons.beanutils.BeanUtils; import java.lang.reflect.InvocationTarg ...

  4. std::tr1::function和bind组件

    C++中std::tr1::function和bind 组件的使用 在C++的TR1中(Technology Report)中包含一个function模板类和bind模板函数,使用它们可以实现类似函数 ...

  5. Django发送邮件和itsdangerous模块的配合使用

    项目需求:用户注册页面注册之后,系统会发送一封邮件到用户邮箱,用户点击链接以激活账户,其中链接中的用户信息需要加密处理一下 其中激活自己邮箱的smtp服务的操作就不在加以说明,菜鸟教程上有非常清晰的讲 ...

  6. python第三方库-图像处理库pillow

    python图像处理库pillow 安装 pip install pillow 使用 导入 from PIL import pillow 读取图像 picture = Image.open('test ...

  7. VMware Ubuntu18.04 安装及配置笔记

    安装Ubuntu 下载虚拟机VMware 下载镜像Ubuntu 过程略, 参考 https://zhuanlan.zhihu.com/p/38797088 Ubuntu配置 特别提示: 在Ubuntu ...

  8. Erasing Substrings CodeForces - 938F (字符串dp)

    大意: 给定字符串$s$, 长度为$n$, 取$k=\lfloor log2(n)\rfloor$, 第$i$次操作删除一个长度为$2^{i-1}$的子串, 求一种方案使得, $k$次操作后$s$的字 ...

  9. postgres 常规操作杂记

    分布式:1.扩容不方便(数据重分布)2.分布键变更很麻烦3.分布键选择(架构设计)谨慎4.跨库join性能差5.分布式事务性能差6.sql限制多,功能确实多7.应用改造成本巨大8.全局一致性时间点恢复 ...

  10. 第二章:排序算法 及其他 Java代码实现

    目录 第二章:排序算法 及其他 Java代码实现 插入排序 归并排序 选择排序算法 冒泡排序 查找算法 习题 2.3.7 第二章:排序算法 及其他 Java代码实现 --算法导论(Introducti ...