noip2018 考前提醒!
适应Noilinux
1.终端操作
打开终端 \(Ctrl+Alt+T\)
打开文件夹 \(cd\) +名称
新建文件夹 \(mkdir\) +名称
打开 \(vim\) 配置 \(vim ~/.vimrc\)
打开 \(vim\) 文件 \(vim\) + 文件名
2.强大的\(Vim\)配置
set nu
set mouse=a
set tabstop=4
set shiftwidth=4
set autoindent
set smartindent
inoremap ( ()<ESC>i
inoremap [ []<ESC>i
inoremap { {}<ESC>i
inoremap " ""<ESC>i
inoremap ' ''<ESC>i
color desert
map <F9> <Esc>:w<CR>: !g++ % -o %< && ./%< <CR>
imap <F9> <Esc>:w<CR>: !g++ % -o %< && ./%< <CR>
3.\(Vim\) 操作
复制 \(n + yy\)
粘贴 \(p\)
删除 \(n+dd\)
撤销 \(u\)
退出死循环 \(Ctrl+c\)
放大字号 \(Ctrl+shift+'='\)
缩小字号 \(Ctrl+'-'\)
保存 \(:w\)
退出 \(:q\)
进入插入模式 \(i\)
退出插入模式 \(Esc\)
4.对拍
system("./data > data.in");
system("./1 < data.in > try1.out");
system("./2 <data.in > try2.out");
if(sytsem("diff try1.out try2.out")) printf("WA\n");
else printf("AC\n");
5.千万不要闲的用鼠标滑轮!会意外退出!
6.写 \(Vim\) 时刻注意保存!
7.\(Noilinux\) 密码 123456
易犯错误
1.头文件
别忘了 #include<cmath> 和 #include<cstring>
对拍测时间 #include<ctime> (\(clock()\))
2.\(using\) \(namespace\) \(std;\) 别忘写!
3.数组大小
无向图边 \(m \times 2\) ,注意边数与点数
不同数组大小不同时一定要区分!
for(int i=0;i<MAXN;i++) 注意取不到等!
4.数组名称不要搞混
变量(\(i\),\(j\))别写反
5.取模运算
出现减法时 \((\%P+P)\%P\)
需要取模的变量,在任何操作后都要去取模!不要漏!
6.溢出
判断 \(int\) 是否需要转 \(long long\)
运算中间量要不要转
7.\(double\) 问题
判断相等时 \(fabs(r-l)<eps\)
8.位运算
注意优先级,疯狂加括号
不要轻易取反(符号也会变)
9.做题细节
看题不要看漏!题目最细小的地方!!
考虑特殊情况,不要漏!
10.想题时
多举反例,想出一些思路是先别急着高兴,往后想
限时想题,及时放置
动态规划时间复杂度=状态数 \(\times\) 转移时间!转移时间别漏了!
11.输入大于 \(10^5\) 加读入优化
12.代码实现细节
树链剖分:
求重子时别忘了 size[u]+=size[v]
根节点不要 \(dfs\) 两遍;在 \(dfs\) 前赋值
倍增:
数组下标问题,别越界
线段树:
下放 \(lazy\) 的同时正确更新 \(sum\)
结构体名别写错
强连通分量:
\(vis\) 表示进栈情况:0--未进过,1--在栈中,2--已出栈
字符串哈希:
想好是否真的可用
加1减1的事情想清楚,多对拍
并查集:
路径压缩 int getfa(int x) { return x==fa[x] ? x : fa[x]=getfa(fa[x]); }
初始化 \(fa[i]=i\)
\(Dijkstra\):
堆优化,\(pair\) 注意第一关键字为 \(dis\)
\(SPFA\):
\(dfs\) 版的 \(vis\) 表示是否正在遍历
判负环可将 \(dis\) 都设成0
差分约束系统:
大于等于还是小于等于
欧拉回路:
注意在访问完一个节点后,将其加入倒叙的 \(ans\) 中
平衡树:
更新 \(size\) 等时别忘了加上自己的
常见思想
1.求某某最值 -> 转化为二分+判定(前提有单调性)
2.问题分解
3.将问题等价转换
4.有时多求一些东西,包含了答案
5.图论与数据结构相结合,动态规划、数论与图论结合(分层图)
猜结论,找规律——数论大胆推&发现;图论谨慎证明;动规小心陷阱
情况考虑周全——多举反例&特殊例子;眼光放开
不要想麻烦——排除干扰,简化题意;从简单算法(二分、数组)想起
小技巧
1.预处理,前缀和…
2.枚举子集时 for(int i=t;i;i=(i-1)&t)
3.用 \(stl\) 中的 \(set\)
noip2018 考前提醒!的更多相关文章
- NOIP2018考前抱佛脚——图论基础复习
目录 存图方式 邻接矩阵存图 邻接表存图 链式前向星 最小生成树 例1 P1536 村村通 题目描述 输入输出格式 输入输出样例 标程 例2 P1546 最短网络 Agri-Net 题目背景 题目描述 ...
- NOIP2018考前抱佛脚——搜索复习
目录 搜索 DFS 例1 P1101 单词方阵 题目描述 输入输出格式 输入输出样例 标程 例2 P1605 迷宫 题目背景 输入输出格式 输入输出样例 标程 例3 P1019 单词接龙 题目描述 输 ...
- NOIP2018考前抱佛脚——数据结构基础及STL实现
目录 动态数组 栈 队列 优先队列 动态数组 srand(time(0)); std::vector<int> qwq; for(int i = 1;i <= 10;++i) qwq ...
- Noip2018 考前准备
目录 基础算法 二分 模拟(未补) 高精(未学习) 搜索(未补) 排序 图论 树的直径 树的重心 最短路算法 Spfa Dijkstra Floyd 最小生成树 kruskal 数论 线性筛 线性筛素 ...
- 论一个蒟蒻的脑子里可以有多少坑(貌似咕了……目前更新保持在noip阶段)
就是错题整理了,其实也会把一些不该犯的失误整进来. 其实之前一直拖着不想写,直到某次模拟赛,看错了2道题,顺便爆了一道题的int(没错第一个点就会爆)之后爆零了,吓得我赶紧把这篇博客搞出来了..... ...
- 初征——NOIP2018游记
前言 从最初接触oi到今年noip到来,也已经将近有一年了.从对于程序一窍不懂到现在开始学习算法,只是短短的不到一年的时间罢了.这次noip,不仅仅是我oi生涯的第一次noip,更是相当于是对我这一年 ...
- NOIP考纲总结+NOIP考前经验谈
首先来一张图,很直观(截止到2012年数据) 下面是收集的一些,我改了一下 红色加粗表示特别重要,必须掌握 绿色加粗表示最好掌握,可能性不是很大,但是某些可以提高程序效率 高精度 a.加法 b.减法 ...
- NOIP2018 AFO记
仿佛"距NOIP2018还剩30天"的倒计时还在昨天,没想到这一天来的这么快. 考前在机房嘻嘻哈哈打打闹闹,开玩笑说道"我要AFO了",心里暗暗发誓做好自己,不 ...
- NOIP2018旅游记
2018.12.4更新: GD分数线出了,1=分数线310,1=了 好歹能和cyp交代了吧) 2018.11.28更新: 不好意思,太懒了,加上我也不记得后来发生什么了,总之就这样太监了. noip2 ...
随机推荐
- 2018-2-13-win10-uwp-异步进度条
title author date CreateTime categories win10 uwp 异步进度条 lindexi 2018-2-13 17:23:3 +0800 2018-2-13 17 ...
- Sending Packets LightOJ - 1321 (期望计算)
题面: Alice and Bob are trying to communicate through the internet. Just assume that there are N route ...
- 牛客wannafly 挑战赛14 B 前缀查询(trie树上dfs序+线段树)
牛客wannafly 挑战赛14 B 前缀查询(trie树上dfs序+线段树) 链接:https://ac.nowcoder.com/acm/problem/15706 现在需要您来帮忙维护这个名册, ...
- C++Review5_Swap交换
面试中可能会问到交换两个变量的值有几种实现方式,对这方面有一定了解还是有必要的,简单罗列一下几种方式,具体介绍查看参考链接: 1.中间变量:->这个最常见了 2.加减法: 3.异或法: 4.sw ...
- MBean 描述符
简介 Tomcat 使用 JMX MBean 来实现自身的性能管理. 每个包里的 mbeans-descriptor.xml 是针对 Catalina 的 JMX MBean 描述. 为了避免出现 “ ...
- 异步加载css 和 谷歌浏览器各实用小工具介绍
异步加载css资源 加开页面首屏显示速度使我们前端一直在追求的目标,而css资源在这些优化中同样也是不可或缺的. 一个网站可能有一部分css资源是必须的,他需要在页面渲染完之前就被加载完,并和html ...
- hadoop中 namenode的持久化
一.为什么namenode持久化 namenode通过内存存储hdfs集群的元数据(目录结构 文件信息 块对应关系),如果内存出现问题,那么会数据丢失,需要通过持久化,把内存中的数据定期的存储在硬盘中 ...
- TCP/IP||Traceroute
1.概述 由Van jacobson编写的工具,用于探索tcp/ip协议,使用ICMP报文和首部TTL字段,TTL字段由发送端设置一个8bit字段,初始值为RFC指定,当前值为64, 每个处理数据的路 ...
- ansible安装与核心组件详解
第1章 安装anisble 1.1 安装epel源 rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarc ...
- 【题解】P2521 [HAOI2011]防线修建(动态凸包)
[题解]P2521 [HAOI2011]防线修建(动态凸包) 凸包是易插入不好删除的东西,按照剧情所以我们时光倒流 然后问题就是维护凸包的周长,支持加入 本来很简单,但是计算几何就是一些小地方经验不足 ...