Note - 千年食谱颂
其实是兔子收集的各种下饭操作与名菜食谱。(
零·策略篇
这个真的是,我每次打毛毛虫剖分都是 rush 状态 qwq。像这种 已知代码难度大、不便于调试的算法,尽量在考试前期发现并制定策略。如果不幸在后期才看出来,必须做好止损工作,例如完善其他三题(包括最终检查,freopen
等),若本题已经写了部分分,则另开文件 rush。调试过程中千万不要慌,骂自己几句然后冷静下来,这种长难代码一定要理清思路,写的时候就不要给调试过程挖坑。
By the way,注意若有多个代码模块逻辑上高度相似(比如复制粘贴改变量名这种),一定小心有区别的地方;若在一处发现了 bug,立马考虑其余几处是否有相同 bug。
壹·读题篇
「LOCAL/20211115」毒瘤聒噪怪:
- 以为是对于 \(k=1..n\) 分别求,原来是对 \(k=1..n\) 求和。你稍微看一样样例也不至于浪费一个小时。
- 我谢谢你。
- 贪心显然,每次给定 \(K\)?那就根号分治……Woc 根本过不去!自闭一个小时发现 \(K\) 是常数,麻了。注意多次询问是否共用常量参数。
贰·思路篇
- 幸好是别人的号。本来的结论伪了,重新修正后还沿用原结论“需要两边扫一遍”的要求,就死啦死啦。
- 出于对点分的热爱尝试将二维偏序优化至线性.jpg
- 瞬间推出 SG 函数有取模,瞬间忘记取模转化起手式:\(x\bmod y=x-\lfloor\frac{x}{y}\rfloor y\),并且整除结果是可枚举的。这样才能进一步转化。
- 有的题,真就该傻瓜题用傻瓜方法。热烈祝贺 OneInDark 玄学数论分块嵌套 + 莫比乌斯反演 + 剪枝完成了暴力能过的题目!
叁·实现篇
《不愿透露姓名的题目》
- 交换非负整数,
a ^= b ^= a ^= b
,当a
和b
指向同一个内存位置,语句等价于a=0
。
char s[...];
然后std::cin >> (s + 1);
CE 了,本地没警告啊……
- SPFA 手写队列(队头队尾移动指针),长度只开结点数。
- 预处理 \(2^i\),模 \(p\),但它被放在指数上。
「WF 2011」「BZOJ #3963」MachineWorks:
- 函数形参的类型推导(eg
int func(auto a)
)是 C++20 标准的语法。
std::set::iterator
自加最坏 \(\mathcal O(\log n)\)。
- 换根 DP,因为删除一个儿子后还要求最大和次大,所以得维护前三大,但是判断细节就很细节(?)调了老久。诸如此类几个东西比大小,反复检查,举例验证,出 bug 时优先核验!
- 「名菜警告」:记得判 \(u\) 的零级祖先为 \(u\) 自身,否则直接用
__builtin_clz(k)
是未定义的。
- 点分治,分治中心的贡献没有加在桶里。
- 有一个
if
用于剪枝,但在极限数据时只会变成常数。为了卡常把它删掉了,而没想到小数据也会因此跑满,全部 T 飞了 qwq。
- \(n\) 打成 \(m\)!\(n\) 打成 \(m\)!你他娘不是 \(m\) 打成 \(n\) 就是 \(n\) 打成 \(m\)!
「CERC 2016」「洛谷 P3679」Bipartite Blanket:
- Two-pointers,其中一个指针扫到 \(-1\) 就不扫了,但其实这其实是意味着接下来一整个序列都合法。
- \(n,m,q\) 反复手误,你再敢不造 \(n,m,q\) 互异的数据检查就去死吧。(
「NOI 2016」「LOJ #2083」优秀的拆分:(By OneInDark)
「名菜警告」:我们写 SA 一般有个 cmp 函数:
auto dif = [&]( const int x, const int y )
{ return id[x] != id[y] || id[x + w] != id[y + w]; };
x + w
会越界……吗?并不是,若越界,id[x] != id[y]
……吗?还是不是,当x == n - w + 1
,有可能刚好越界到id[n + 1]
,一般数组会有冗余空间所以不会 RE,但多次后缀排序一定要清空到 \(n+1\)!!!错误示例(By OneInDark):WA submission。
- 高斯消元,
EPS=1e-7
忽略一些系数导致巨大精度误差。在确定不影响复杂度的情况下,实数消元还是无脑全部枚举一遍吧。
求矩阵并的那种线段树的
pushup
:inline void pushup( const int u, const int len ) {
// cnt[u] = cvr[u] ? len : cnt[u << 1] + cnt[u << 1 | 1]; // RE.
cnt[u] = cvr[u] ? len : len > 1 ? cnt[u << 1] + cnt[u << 1 | 1] : 0;
}
思考一个结论的时候把“平移相等”顺口说成“对称”,代码写出来真写成关于对称轴对称了……
\(a_{i,j}\in[-10^9,10^9]\),四个加起来没开
long long
。每次测样例必须所有样例同时通过;检查代码时检查细节、逻辑思路的正确性。
- 根号分治,一种情况在差分,一种情况没差分,写着写着就乱套了。任何分类求解的算法一定要用同组数据测试不同情况!
- 可持久化线段树写成动态开点完全没有持久化线段树。
- 瞬间看出标算结论,瞬间想出标算,一经思考:“我草这 treap 被 split 成这么散怎么还原?”痛失一百分。有时候平衡树非常吻合思路的进程,但实现时可以考虑权值线段树作为细节少、易调试的数据结构。
- 线段树二分,
if (l == r)
这个 statement 里不要忘记就算 \(l=r=1\)(整棵树左端点)也是有可能不在二分上界里的,注意判。
清空了,但没有完全清空。
static std::string str;
while (...) {
if (...) { do something with str; }
else { str.clear(); }
}
do someting with str;
// str.clear(); !!!
- 有一个东西
h
,我把它换成rh
,并重新定义了h
的含义,然而某处本应是rh
的地方没改……
Note - 千年食谱颂的更多相关文章
- 魅蓝Note有几种颜色 魅蓝Note哪个颜色好看
http://www.pc841.com/shoujizhishi/39882.html http://news.mydrivers.com/1/359/359443.htm 魅族发布首款千元高性价比 ...
- 【Common】NO.81.Note.1.Common.1.001-【各种英文符号的表示及念法】
1.0.0 Summary Tittle:[Common]NO.81.Note.1.Common.1.001-[各种英文符号的表示及念法] Style:Common Series:Common Sin ...
- ZooKeeper食谱(八)
使用ZooKeeper构造高级别应用的指南 在这个文章中,你将会发现使用ZooKeeper来实现高级别功能的指南.所有的它们在客户端上被实现而不需要ZooKeeper特别的支持.希望社区将注意到这些约 ...
- Twitter如何在数千台服务器上快速部署代码?
答案是:用BT,也就是你我应该都很熟悉的BitTorrent. 对于网站经营者.创业者来说,扩展性的问题是在网站流量成长过程中势必会面对的问题,如何建立一个具有扩展性的架构(scalable arch ...
- [翻译]魅族的M1 Note是十分廉价(dirt-cheap)的iphone5C增强版
Meizu's M1 Note is a dirt-cheap iPhone 5c on steroids 魅族的M1 Note是十分廉价(dirt-cheap)的ihone5C增强版 While m ...
- 神探Python程序员,带你千里捉小三!(附详情代码)
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 王翔 清风Python PS:如有需要Python学习资料的小伙伴 ...
- 我是青年你是良品-魅蓝NOTE 2
2" title="我是青年你是良品-魅蓝NOTE 2"> 明天魅蓝即将迎来自己的新品发布会.选择儿童节的第二天后最喜爱的手机品牌.让其成为真正青年的良品. 在 ...
- Paddle Release Note
Paddle Release Note 重要更新 飞桨paddle框架2.0.0版本有如下重要更新: 编程范式:默认开启动态图模式进行模型开发和训练,通过动转静的方式进行模型部署和训练加速.如果需要使 ...
- 三星Note 7停产,原来是吃了流程的亏
三星Note 7发售两个月即成为全球噩梦,从首炸到传言停产仅仅47天.所谓"屋漏偏逢连天雨",相比华为.小米等品牌对其全球市场的挤压.侵蚀,Galaxy Note 7爆炸事件这场连 ...
随机推荐
- CentOS 7安装Etherpad(在线协作编辑)
Etherpad 是一个线上共制平台,是基于网络的实时合作文档编辑器,三.四个人可以坐在自己电脑前,同时对一份文档修改,也同时能看到其他人的修改. CentOS 7 安装 Etherpad 1.先安装 ...
- vue中computed的作用以及用法
在vue中computed是计算属性,主要作用是把数据存储到内存中,减少不必要的请求,还可以利用computed给子组件的data赋值. 参考地址:https://www.jianshu.com/p/ ...
- react中state与setstate的使用
我们可以利用state来定义一些变量的初始值 //放在construcor里 this.state = { list: [1, 2, 3] } 要更改state里的值,注意要遵循react里immut ...
- 简述伪共享和缓存一致性MESI
什么是伪共享 计算机系统中为了解决主内存与CPU运行速度的差距,在CPU与主内存之间添加了一级或者多级高速缓冲存储器(Cache),这个Cache一般是集成到CPU内部的,所以也叫 CPU Cache ...
- Go 中实现用户的每日限额(比如一天只能领三次福利)
如果你写一个 bug 管理系统,用了这个 PeriodLimit 你就可以限制每个测试人员每天只能给你提一个 bug.工作是不是就轻松很多了? 如今微服务架构大行其道本质原因是因为要降低系统的整体复杂 ...
- PAT 乙级 1002. 写出这个数 (20)(C语言描述)
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式:在一行内输出n的各位数字之和的每 ...
- 《剑指offer》面试题34. 二叉树中和为某一值的路径
问题描述 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶节点所经过的节点形成一条路径. 示例: 给定如下二叉树,以及目标和 sum = 22, 5 ...
- Spark基础知识详解
Apache Spark是一种快速通用的集群计算系统. 它提供Java,Scala,Python和R中的高级API,以及支持通用执行图的优化引擎. 它还支持一组丰富的高级工具,包括用于SQL和结构化数 ...
- Docker 与 K8S学习笔记(十八)—— Pod的使用
Pod 是一组紧密关联的容器集合,它们共享IPC.Network和UTS namespace,是 Kubernetes 调度的基本单元.Pod 的设计理念是支持多个容器在一个 Pod 中共享网络和文件 ...
- linux文件编辑器快捷方式
一:文件编辑器快捷方式 7.光标快速移动快捷方式 ①. 快速切换光标到底行 shift + G ②. 快速切换光标到首行 gg ③. 快速跳转到行首 0 ④. 快速跳转到行尾 shift + $ ⑤. ...