• Mistakes(Updating)


    1.当调试时发现无法正常调用函数时,检查是否发生爆栈

       对于每个栈仅有4MB的空间,开int只能开大约5*10^5。

       大数组一定要开全局变量

    2.当long long=int*int时会爆int,一定要注意

      在进行long long计算时,最好全部开成long long ,或加上1LL

    3.vector.size()的类型为unsigned int

      当用其做减法时一定要注意边界条件,防止差小于0溢出

    4.在求特殊最值时,一定要特殊定制初始化值,不能套用平常初始值,防止初始值不够

       Ex:1<<30 > 1e9

    5、由于返回类型为int和bool的默认返回值是1,因此有些时候要注意在函数结束前return false.

    6、注意计算几何的精度问题,要比答案多算2到3位,否则可能WA

          (Codeforces 8D)

    7、注意模数不能为零

          当p mod q时要对q=0时特殊处理

          (Codeforces #480 A)

    8、注意答案的大小写

    (BZOJ 2964)

    9、scanf("%c)和getchar()有相同的问题:会读入 等缓冲区的遗留字符

    尽可能的用char数组和scanf("%s")的组合

    (BZOJ 2819)

    10、在写Trie树时,CNT的初始化要根据根节点数目而定

    如果有n棵树,则CNT要初始化为n+1

    11、在线性基求XOR最大值时

    如果res初始值不为0,不能对线性基中的1直接添加,而要使用MAX逐个判断

    12、如果在读入long long 时使用IO优化

           read()中的INT要改为LONG LONG!!!

    13、注意x组成y至少要多少个这类问题的书写:

    y=y/x+(y%x>0)   ||    y=(y+x-1)/x  (不要漏>0

    14、有多个括号要留心每个括号的位置啊,多看几遍

    while((f=dfs(S,T,INF))>0)

    这里的>0一开始放到第2个括号里了,结果f每次就都是0或1了……囧,调了1h

    15、像网络流这样执行过一边就会对原数组产生影响的模块,

             执行过一次后想调试/再次调用时,不能再执行一遍

    16、由于模板中大部分数据都是int,如果有long long时要特别注意修改原模板中的int

            惨案:

    void add_edge(int from,int to,ll cap)

    17、如果题目中涉及连续相乘且不取模,注意是否需要高精度

    18、Big Integer模板类中牢记存储顺序是从低位到高位的

    重载>时要从后往前判断

    19、能用int计算不用long long,在32位机下,int比long long 快几倍

    20、求SG函数时,初始值最好都设为0,防止异或-1这种情况

    如果使用$vis$数组也一定要第一时间更新,防止陷入死循环

    21、对变量初始化的先后顺序要注意

    EX:cur=0要在st[cur][1]之前初始化

    22、哈希表最好用链式前向星实现

    $vector.clear()$太慢了!

    23、左移、右移比==优先级高,但位与、位或比==优先级低

    24、树状数组$Query$中的$ret$记得初始化!!!

    25、如果$dp$时一开始状态无法填满,选择 一开始特殊处理从0开始循环 !

    26、如果数组下标中有运算,查看是否可能溢出,要开大数组

    27、链式前向星实现的网络流算法的要点!

    (1)$edge$数组的下标一定要从0开始,这样才能使得$edge[i]$与$edge[i^1]$互为反边

    (2)由于上一条原则,$head$数组一定要初始化为-1,而不是-1与0皆可

    28、突然发现自己以前点分治找重心都是假的……

    然而复杂度被证明是正确的:传送门

    不过最好在递归时$vsum=vsum-sz[x](e[i].to=f[x])$

    29、$map,set$存结构体时要重载小于号

    注意重载要写全(特判前面关键字相等的情况),否则前面相等时会有意外情况(不再插入)

    30、OJ上交题前一定要检查是否删掉freopen!!!

    31、哈希的值域一定要从1开始!!!有0明显会出错

    (特别是字符串哈希)

    32、注意三元运算符的优先级!!最好都加上括号!

    33、不能只考虑是否爆$int$,对$1e18$的$longlong$运算时也要注意是否爆$longlong$!

    34、注意多测且一边读入一边处理时要把数据读完,不能break!!!

    35、线段树注意最后一层的更新,不能先$return$!

    36、线段树询问时要保证询问区间和$[1,n]$有交!否则陷入死循环

  • 相关阅读:
    杨老师课堂_VBA学习教程之根据部门列创建工作表
    杨老师课堂_Java核心技术下之控制台模拟微博用户注册案例
    杨老师课堂_Java核心技术下之控制台模拟记事本案例
    杨校老师课堂之JavaScript右下角广告弹框教程
    JavaScript的数组知识案例之随机点名器
    SET QUOTED_IDENTIFIER ON
    SET ANSI_NULLS ON
    OLEDB和ODBC的区别
    教你认识主板上的主要芯片
    递归和迭代有什么区别
  • 原文地址:https://www.cnblogs.com/newera/p/7896937.html
Copyright © 2020-2023  润新知