一、代码:

1、求逆元(原理貌似就是拓展欧几里得,要求MOD是素数):

int inv(int a) {
if(a == 1) return 1;
return ((MOD - MOD / a) * inv(MOD % a)) % MOD;
}

2、底层优化(正确性未验证):

int cmp(int a) {if (!a) return 0; return a < 0 ? -1 : 1;}
int cmp(int a) {return (a >> 31) + (-a >> 31 & 1);} int abs(int x) {return x > 0 ? x : -x;}
int abs(int x) {int y = x >> 31; return (x + y) ^ y;} x = (x == a ? b : a)
x ^ = a ^ b
//等于0返回0,大于0返回1,小于0返回-1
int sgn(double x) {
if(fabs(x) < EPS) return 0;
return x > 0 ? 1 : -1;
}
int sgn(double x) {
return (x > EPS) - (x < -EPS);
} int fastMax(int x, int y) {return (((y-x)>>(32-1))&(x^y))^y;}
int fastMin(int x, int y) {return (((y-x)>>(32-1))&(x^y))^x;}

3、扩栈,这玩意儿在OJ上用能防爆?

#pragma comment(linker, "/STACK:1024000000,1024000000")

4、神速读入fread

struct Reader {
static const int MSIZE = 65536;
char buffer[MSIZE], c;
int l = 0, r = 0;
char readchar() {
if(l == r) {
l = 0;
r = fread(buffer, 1, MSIZE, stdin);
}
return buffer[l++];
}
int readint() {
c = readchar();
while(!isdigit(c)) c = readchar();
int res = 0;
while(isdigit(c)) res = res * 10 + c - '0', c = readchar();
return res;
}
} reader;

二、神牛blog

matrix67

ZKW

watashi

三、专题

动态规划系列:

数位dp模板

字符串系列:

【专辑】AC自动机

计算几何系列:

计算几何相关资料+题目推荐(不定期补充)——gbr的馒头屋

[专题学习][计算几何]

ACM计算几何题目推荐

数学系列:

POJ【数论/组合/博弈论】题目列表

四、(伪)算法教学

字符串系列:

后缀数组学习笔记——罗穗骞倍增算法代码

数学系列:

平面、空间分割最大化

线性筛法

01分数规划

拓展欧几里得求解线性同余方程组——POJ2891

二次同余方程的解

ZJU2004 Commedia dell'arte - 八数码问题有解的条件及其推广

组合计数系列:

Polya定理总结

数论系列:

ACM数论总结

数据结构系列:

高级数据结构之树状数组

主席树——POJ2104

Morris Traversal方法遍历二叉树(非递归,不用栈,O(1)空间)

动态规划系列:

[总结]数位统计模板

图论系列:

一般图最大匹配问题-带花树开花算法

2-SAT输出解的简便方式(附证明)——POJ3683

次小生成树

【AHOI2013复仇】两道有关删边后最短路径维护的猥琐题

JAVA:

ACM之java速成

JAVA之BigInteger(转)【转】【很好用啊】

其他:

IO/ACM中来自浮点数的陷阱(收集向)

正则表达式30分钟入门教程

人造奇迹——二进制位运算的运用

[转帖]typedef使用三部曲

五、OI/ACMer感谢贴/退役贴/经验贴/等等:

ACMer感想帖/退役帖汇总

ACRush 楼天成回忆录

ACRush Topcoder问答语录

WJMZBMR的OI退役贴

大牛对ACM入门菜鸟的一些话——吴垠

edward_mj退役经验帖

acm总结帖_By AekdyCoin

【转】赞一下huicpc035

【转】lonekight@xmu·ACM/ICPC 回忆录

【转】[退役]纪念我的ACM——headacher@XDU

【转】ACM/ICPC生涯总结暨退役宣言—alpc55

六、解题报告

nocow上的URAL题解

2014多校题解官方发布

GDCPC2015题解 by lby@SYSU_Spirit_Moon

GDCPC2016题解 by lby@SYSU | Asiimov

七、其他:

ACM核武器——wuyiqi

热门OJ介绍

数据结构动态演示1:http://www.comp.nus.edu.sg/~stevenha/visualization/

数据结构动态演示2:http://www.cs.usfca.edu/~galles/visualization/Algorithms.html

收集一些关于OI/ACM的奇怪的东西……的更多相关文章

  1. 【封装工程】OI/ACM常用封装

    前言 笔者有的时候无聊,就将一些奇怪的东西封装起来. 范围主要是在\(OI\)或者\(ACM\)中的常见数据结构等. 随着笔者的能力的提升,可能会对原来的封装程序进行修改,并且保留原来的版本. [ST ...

  2. BZOJ-3670 动物园 KMP+奇怪的东西

    YveH爷再刷KMP,DCrusher看他刷KMP,跟着两个人一块刷KMP... 3670: [Noi2014]动物园 Time Limit: 10 Sec Memory Limit: 512 MB ...

  3. OI/ACM 刷题网站 人气OJ简介

         SPOJ简介 SPOJ是波兰最为出色的Online Judge之一,界面和谐,题目类型也非常丰富,适合有一定基础的选手练习,对高手而言也是个提高能力的良好平台. SPOJ题目分类:class ...

  4. OI/ACM最全卡常大招

    NO.10: 循环展开: 在缓存和寄存器允许的情况下一条语句内大量的展开运算会刺激 CPU 并发(蛤?这是个什么原理,算了,反正写了没坏处就这么写吧) NO.9: 特殊运算优化:(或许这真的没用) 取 ...

  5. [打基础]OI/ACM基本功&一些小功能的实现&一些错误(持续更新)

    基本功 前导0 如题,有时候需要把3输出成03这样子,可以调用 cout.width(x); ,x表示以几位,用 cout.fill(x); 来给出前导填充的内容,一般x以char的形式给出 例如可以 ...

  6. IO/ACM中来自浮点数的陷阱(收集向)

    OI/ACM中经常要用到小数来解决问题(概率.计算几何等),但是小数在计算机中的存储方式是浮点数而不是我们在作数学运算中的数,有精度的限制. 以下以GUN C++为准,其他语言(或编译器)也差不了多少 ...

  7. 第七届ACM趣味程序设计竞赛第四场(正式赛) 题解

    Final Pan's prime numbers 题目连接: http://acm.uestc.edu.cn/#/problem/show/1272 题意 给你n,要求你在[4,n]范围内找到一个最 ...

  8. ACM录 之 输入输出。

    —— 简单介绍一下ACM里面的输入输出... —— 主要说C++的输入输出(其实其他的我不会...). —— C++里面有输入输出流,也就是cin和cout,用起来也算是比较方便吧... —— 但是, ...

  9. ACM hust 2.1

    来自咸鱼王的呻吟 http://www.xiami.com/song/3599639?spm=a1z1s.3521865.23309997.1.PbLu7E 配合咸鱼食用效果更佳(右键新窗口打开) 题 ...

随机推荐

  1. js 闭包之一

    既然说闭包的化,我们就先来说说函数.慢慢的进入进入正题 (1)函数申明 f1(); function f1(){ alert(") }//结果 1 (2)函数定义 f1();var f1=f ...

  2. html 之input标签height设置问题

    今天针对这个问题纠结了很久 <input type="button" value="xx" style="height:99px;" ...

  3. Two Sum

    Given an array of integers, find two numbers such that they add up to a specific target number. The ...

  4. EasyTouch绑定事件在电脑上点击有效Android上无效的解决方法

    最近做一个RPG类的游戏发现使用EasyTouch虚拟摇杆插件在电脑上点击有效Android上无效,查找资料发现是Easy Joystick中的一个属性interaction type要设置成 Dir ...

  5. python UnicodeDecodeError: 'ascii' codec can't decode byte 0xa6 in position 907: ordinal not in range(128)

    import sysreload(sys)sys.setdefaultencoding('utf-8')

  6. 后台树状菜单,js实现递归无限分类

    //新闻类别管理 public function new_classify() { $arr = M('news_classify')->where("fid = 0")-& ...

  7. reg

    <div class="login-module"> <div class="wide c login"> <form id=&q ...

  8. Theos 工程

    一.tweak 工程 1.创建步骤 a) terminal cd 到想要存放项目的目录下 b) 按图步骤完成即可 二.工程文件描述 1.control 记录 deb 包管理系统所需的基本信息. 2.a ...

  9. sprint2总结

    在sprint第二阶段的学习过程中,前期和后期在学校网络的支持下我们成功的延迟了把代码上传github的时间,在我们自己感觉上看,完成项目的质量比较理想,在经过sprint第一阶段的学习后,部分上的问 ...

  10. PL/SQL %TYPE和%ROWTYPE的区别【转】

    %TYPE: 定义一个变量,其数据类型与已经定义的某个 数据变量的类型相同,或者与数据库表的某个列的数据类型 相同,这时可以使用%TYPE.         使用%TYPE 特性的优点在于: 1.所引 ...