这篇博客主要是用来记自己写代码的时候犯的各种小技巧和低级失误,好提醒自己,从而尽量缩短debug时间。




点分治

1.求每一个子树到重心的距离的函数接口应该是dfs2(v, eg, e[i].w)而不是dfs2(v, now, 0)。一方面是子树的父亲是当前的重心,而不是进入这一层点分治的点;另一方面别忘了考虑这条边的贡献。




2-SAT

1.建图一定要考虑对称性,即“如果\(x\)成立,则\(y\)必须成立”,那么我们还得考虑如果\(y\)不成立,则\(x\)也不能成立,比如[NOI2017]游戏




哈希

1.觉得有必要的话最好写一个双哈希,防止出题人卡自然溢出。

2取模版哈希在算子串哈希的时候也别忘了取模,要不然就有负数了。

3.哈希表是真的快!尽量用哈希表代替map,防止被卡常。(比如[NOI2016]网格,刚开始用map有两个点怎么卡也卡不过去,改成哈希表后只用了300多ms)




主席树

1.查询的时候,判断是否往右走的条件是根据左区间而定,即t[t[now].ls].sum - t[t[old].ls].sum,千万别手滑写成了t[now].sum - t[old].sum




线段树

1.较复杂的线段树一般需要推推式子才能知道要维护啥。推式子时有一个技巧,就是下标尽量都保证是全局的编号,而不是某一个区间中的第几个,这样区间合并的时候往往会简单的多,不用考虑两个区间的左右关系,比如[HAOI2012]高速公路



数论,数学

1.万一遇到某一个题过程中要求组合数却不能取模,可以尝试取log,最后再用exp()转换成真正的值,比如HDU4254 A Famous Game

2.求两个数的lcm的时候为了防止爆int或long long,要先除以gcd,再乘以另一个数。

3.组合数一定要特盘\(m > n\)的情况,尤其是Lucas定理的时候!




lucas定理

1.在一篇博客上看到lucas定理可以不用递归,而是每次把\(n\)和\(m\)都除以\(p\)直到0。有如下代码

In ll C(int n, int m)
{
if(n > m) return 0;
return fac[n] * inv[n - m] % mod * inv[m] % mod;
}
In ll lucas(int n, int m)
{
if(m > n) return 0;
ll ret = 1;
for(; m; n /= mod, m /= mod)
ret = ret * C(n % mod, m % mod) % mod;
return ret;
}

**高斯消元**
1.对于每一次的主元,我们要找最大的数那一行,为了减小误差。不是最小的!


**SAM**
1.关于求每一个节点的endpos数量:插入的时候标记这个节点是一个结束位置,最后我们从下往上递归加一遍,就是每一个的endpos数量。有好长一段时间我都以为子树大小=endpos数量。后来才突然想明白,克隆出的节点的初值是0,因为他不是一个结束位置,所以我们求出来的每一个节点的endpos数量不等于子树大小。


**高精度**
1.高精乘低精是先乘再进位!先进位再乘还得有点别的运算。(好久不写调了半天,还看了[我以前的博客](https://www.cnblogs.com/mrclr/p/8525701.html))


**杂项**
1.`assert()`是一个debug用的好东西,当括号里的条件不成立时,会立即停止运行,并给出提示(在高级的oj上会告诉你),包含在``库里。
2.离散化数组一定要算好空间:比如把一堆区间离散化,就要开二倍。因为每一个区间的左右端点都要算进去。
3.看到异或,第一反应是每一位单独考虑!
4.`clock()`是clock_t数据类型,返回的是long int。所以要是想保证程序运行时间小于0.9秒的话,必须强制转换成double,即`if((double)clock() / CLOCKS_PER_SEC)

各种trick和细节错误汇总的更多相关文章

  1. 编程中易犯错误汇总:一个综合案例.md

    # 11编程中易犯错误汇总:一个综合案例 在上一篇文章中,我们学习了如何区分好的代码与坏的代码,如何写好代码.所谓光说不练假把式,在这篇文章中,我们就做一件事——一起来写代码.首先,我会先列出问题,然 ...

  2. Entity Framework学习笔记——错误汇总

    之前的小项目做完了,到了总结经验和更新学习笔记的时间了.开始正题之前先啰嗦一下,对之前的学习目标进行一个调整:“根据代码生成表”与“生成数据库脚本和变更脚本”合并为“Code First模式日常使用篇 ...

  3. 李洪强iOS开发之OC常见错误汇总

    // //  main.m //  16 - 常见错误汇总 // //  Created by vic fan on 16/7/13. //  Copyright © 2016年 李洪强. All r ...

  4. Python常见的错误汇总

    +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 错误: [错误分析]第二个参数必须为类,否则会报TypeError,所以正确的应 ...

  5. PHP常见错误汇总

    日常开发和调试的时候,经常会遇到一些错误,光怪陆离的不知所以,所以,特此将错误汇总一下,借鉴!!! 1. 原因分析:  一般可能是该文件出现了问题,检查一下代码和格式,是否出现开始的地方出现了空格,或 ...

  6. Quartus II 中 Verilog 常见警告/错误汇总

    Verilog 常见错误汇总 1.Found clock-sensitive change during active clock edge at time <time> on regis ...

  7. android studio 错误汇总以及解决办法

    android studio 错误汇总以及解决办法  参考 https://www.jianshu.com/p/7c7de6562231 问题1. Error:Execution failed for ...

  8. react 报红错误汇总

    react  报红错误汇总 一.Uncaught TypeError: Cannot read property 'value' of undefined 未知类型错:无法读取未定义的属性“value ...

  9. ibatis错误汇总

    1) 错误:The prefix "context" for element "context:property-placeholder" is not bou ...

随机推荐

  1. 14.1 Scroll说明和注意事项

    使用scroll滚动搜索: 比如全文搜索10万条数据,不能一次全搜出来返回,太耗时了.通常是一批一批的获取结果,滚动搜索     1. 第一次搜索时,会生成这批数据的快照,下次再搜的时候,基于此快照进 ...

  2. js实现frame框架部分页面的刷新

    一.先来看一个简单的例子: 下面以三个页面分别命名为frame.html.top.html.bottom.html为例来具体说明如何做. frame.html 由上(top.html)下(bottom ...

  3. UI5-技术篇-JS函数eval动态执行

    <html lang="en"> <head> <meta charset="utf-8" /> <title> ...

  4. UCOSIII系统内部任务

    1. 空闲任务 空闲任务是UCOSIII创建的第一个任务 空闲任务是UCOSIII必须创建的 空闲任务优先级总是为OS_CFG_PRIO_MAK-1 空闲任务中不能调用任何可使空闲任务进入等待态的函数 ...

  5. python使用tkinter无法获取输入框的值

    如果遇到:使用tkinter无法获取输入框Entty()的值的问题,需要检查一下,是否在定义Entry()时立即进行了pack() 会出现使用entryname.get()报错 解决方法:把定义和pa ...

  6. python实战项目

    没有一个完整的项目开发过程,是不会对整个开发流程以及理论知识有牢固的认知的,对于怎样将所学的理论知识应用到实际开发中更是不得而知了! 以上就是我们在学习过程中必须要有项目实战开发经验的原因,其实无论项 ...

  7. MySQL小记——数据格式化

    记录下今天在项目中出现的一个小问题. 将通过除运算获得的结果数据进行保留两位小数的处理时,我用了MySQL 的 FORMAT(X, D)函数,之前一直没有出现问题,但是由于周期性更新的数据库中突然出现 ...

  8. 【大数据技术能力提升_2】numpy学习

    numpy学习 标签(空格分隔): numpy python 数据类型 5种类型:布尔值(bool),整数(int),无符号整数(uint).浮点(float).复数(complex) 支持的原始类型 ...

  9. Windows性能计数器监控实践

    Windows性能计数器(Performance Counter)是Windows提供的一种系统功能,它能实时采集.分析系统内的应用程序.服务.驱动程序等的性能数据,以此来分析系统的瓶颈.监控组件的表 ...

  10. ARP欺骗之ettercap图形化界面

    ARP欺骗原理: 在每台主机中都有ARP缓存表,缓存表中记录了IP地址与MAC地址的对应关系,而局域网数据传输依靠的是MAC地址(网络设备之间互相通信是用MAC地址而不是IP地址) 一.ARP欺骗 工 ...