NOIP以前可能会持续更新

写在前面

NOIP好像马上就要到了,感觉在校内训练里面经常被虐有一种要滚粗的感觉(雾。不管是普及组还是提高组,我都参加了好几年了,结果一个省一都没有,今年如果还没有的话感觉就真的要滚大粗退役回去念书了QAQ。于是有了压力就来刷(水水水)题。感觉校内OJ的题库还挺多的就开始做校内OJ的题。(本校的其他神犇都在其他各种OJ上屠丧题我感觉好虚啊!)于是把这几年NOIP的原题拿出来做了下。
(我蛮立个flag:如果NOIP过了就买BZOJ权限号。。。)

历年NOIP提高组一句话(口胡)题解

NOIP2015

D1T1神奇的幻方:小模拟,当时too young too simple考场花了0.5h才过。

D1T2信息传递:找最小环,考场上队开小了丢了40pt,懒得再写就把考场上代码改了一个地方过了。

D1T3斗地主:张哥哥出的大爆搜游戏题= =b。。。当时naive连30pt都没拿到。后来听了题解才知道是贪心+爆搜顺子。刚听完题解的时候没听完整于是连单牌对子3带1什么的也拿去爆搜了,于是就一直TTT。。。再看了一遍题解才知道除了顺子以外的都可以贪心= =b。。。顺便做了下uoj的斗地主加强版,感觉好恶心啊= =b,各种97分,Wrong Answer on extra test x。好惨啊,于是就把贪心推了改成DP了才终于过了。。。

D2T1跳石头:考场上貌似没判最后一块石头到终点的情况。运气好过了90pt。懒得调考场代码于是就重新敲了一遍过了。

D2T2子串:不会DP是硬伤啊~记f[i][j][k][0/1]为做到i位取/不取时,B串匹配到第j位,被分成k段的方案数,然后瞎jb乱DP一下就好了。

D2T3运输计划:二分+树上差分。好像其他神犇有并查集等只有一个log的做法的。然而我看不懂。。。我因为太弱只看懂了二分+差分的log方的做法:先二分一个答案,然后最优化问题就转化为了判定性问题。维护所有大于这个值的链的交,这个可以用树链剖分来在dfs维护差分标记来实现。然后把链的交上的最大的拿去变0,如果最长链-这个最大值小于等于这个值显然就是成立的。被uoj的extra test卡常数卡得欲仙欲死


NOIP2014

D1T1生活大爆炸版石头剪刀布:模拟。

D1T2联合权值:好早以前过的题了= =b,应该强行不难吧。。。

D1T3飞扬的小鸟:挺丧病的DP。转化为完全背包来求解。转移很多注意细节= =b。

D2T1无线网络发射器选址:模拟。

D2T2寻找道路:反着搜一遍再正着搜一遍。

D2T3解方程:一道挺玄学的题。(据说uoj这题不开放hack,好像只要对着模数卡都能卡掉)做法是取几个质数p然后预处理出0~p-1的数能否使得这个多项式在模p意义下值为0。接着再枚举1~m,看一下i%p是否成立,如果你取的所有质数都是成立的,那么这个数有很大概率就是方程的根(雾。好像bzoj上的数据加强过,把20000以内的质数都卡掉了。


NOIP2013

D1T1转圈游戏:快速幂。

D1T2火柴排队:转化成逆序对模型,然后用归并或树状数组来做。

D1T3货车运输:带权并查集或者倍增。(我写的是倍增,然而带权并查集跑得更快)

D2T1积木大赛: 结论题。差分以后正的加起来。

D2T2花匠:最长波动子序列。DP。

D2T3华容道:码农图论题。把图预处理出来以后跑SPFA。


NOIP2012

D1T1Vigenère 密码:模拟。

D1T2国王游戏:按a*b贪心,比较坑爹的是要写高精度。

D1T3开车旅行:倍增。用排序+链表处理出一个点的前驱后继什么的就可以求出每个点A和B跳到哪里。第一问和第二问的做法都很相同。

D2T1同余方程:exgcd模板题。

D2T2借教室:二分+差分。

D2T3疫情控制:二分+贪心+树链剖分/倍增。细节题啊!情况非常多。我们发现答案是单调的,于是就先二分一个答案,然后军队就可以总结成两种情况:可以跳到根的和不能跳到根的。先把不能跳到根的就跳尽量往上跳。然后对于那些能跳到根的,如果当前的大的子树内的叶子已经都封住了那么跳到根不然就选一个离根最远的跳到离根最近的节点。然后将可以跳到根的军队的剩余时间和需要军队的子树的距离都排序,从大到小匹配即可。


NOIP2011

D1T1铺地毯:模拟。

D1T2选择客栈:DP。社会实践的时候无聊在手机上写的。记一下上一次同色点的位置和上一次小于p的点的位置,还有之前有多少个同色点,然后分两种情况转移就好了。

D1T3mayan游戏:人民群众喜闻乐见的大爆搜游戏题。好早以前校内训练的时候写的。有时间一定要再写一次

D2T1计算系数:二项式定理。

D2T2聪明的质检员:二分。我们注意到Y关于W的函数是一个单调递减的函数。于是我们就假装这个函数与Y=S这条直线有交点,那么就可以二分。二分出来“零点”以后前后减一下看看哪个更小就好了。

D2T3观光公交细节贪心题。据说考场上有神犇半小时想出贪心策略然后a掉了我们发现每个加速器的贡献是独立的,所以我们可以贪心。考虑一下一条路使用加速器对于答案的贡献,恰好是这条路终点到下一个停车点中间的下车人数。所以我们对于每一个加速器枚举用在哪条路上是最优的,然后每次再维护一下停车点的改变(因为使用了加速器以后可能会导致原来不停车的地方停车了)。所以对于每次的加速器都重复这个操作就好了。


NOIP2010

乌龟棋:很基础的DP题,然而我在省夏之前还不会(我好弱啊)。把牌的数量来记状态。然后就可以转移啦。

机器翻译:直接用队模拟。

关押罪犯:二分+并查集判是否能构成二分图。这个做法理论上是对的,但不知为何在VijosTLE了。于是就改成了把边排序以后往里面加边直到不是二分图为止。

引水入城:拓扑排序。我记得省夏讲过这道题。。。从第一行每个点出发到达最后一排的点的集合必然是一个连续的区间。然后原图用偏序关系表示的话就是一个DAG,我们逆着拓扑序把区间贡献上去,然后最后再用第一行的线段做一遍最少区间覆盖就好了。细节有点多的题,不过想清楚了再写应该就会比较好写。


NOIP2009

潜伏者:直接模拟。

Hankson 的趣味题:好像正解是什么神奇的做法。然而我根号枚举好像就过了。。。

最优贸易:正着SPFA一遍求出路径上最小值再反着SPFA一遍求出路径上最大值。

靶形数独:又是人民群众喜闻乐见的大爆搜游戏题。好像好多人都用DLX的样子。然而我并不会DLX于是就想静态确定搜索序。然而搜索姿势不对被卡了一整个晚上QAQ最后强行改成n+e学长的搜索姿势才跑的过去TAT。感觉还是有时间去学学DLX比较稳吧。


NOIP2008

笨小猴:模拟题。

火柴棒等式:模拟题。

传纸条:二取方格数。费用流在Vijos上TLE了差评!!!我洋洋洒洒敲完费用流模板结果交上去TLE了简直不爽。于是就改成多线程DP。

双栈排序:网络上的题解貌似都是O(n^2)的?可是我不太会,我只会贪心,于是调了巨多发才过。也可能是原题数据比较弱没卡贪心?我也不知道我的贪心正确性如何,不过复杂度比正解优,是线性的。


NOIP2007

统计数字:计数排序。

字符串的展开:细节模拟。

树网的核:把最长链搞出来然后用双指针单调队列搞一搞。复杂度线性。

矩阵取数游戏:挖个坑。。。代码还来不及写。我觉得题解大概是一个区间DP+高精度。


更早的NOIP

[NOIP2006]能量项链 区间DP。

[NOIP2005]过河 DP。类似离散化的结论,减少了无用的转移状态。

[NOIP2005]等价表达式 双栈表达式解析。细节题!!!

[NOIP2005]篝火晚会 结论题。答案会等于最少有多少个数不等于它在环上的下标。会等于n-偏移量的最多的出现次数。

[NOIP2002]字串变换 双搜。用map/hash来维护一下搜索到某个串的步数。学到的新姿势:双搜的时候可以直接用两个队一起bfs,不用一个先bfs一半另一个再bfs一半。

[NOIP2000]三取方格数 费用流或多线程DP。

其他的刷题记录

2016.10.26

BZOJ2815:[ZJOI2012]灾难 在DAG上用倍增构造支配树。答案就是支配树的子树大小。(NOIP难度的校内训练出这道题的加强版,把模型转到了最短路DAG上。其实就是初赛最后一题的加强版,而且还丧心病狂地卡SPFA,我改了堆优dj才过。)

2016.10.28

BZOJ1968:[Ahoi2005]COMMON 约数研究 推了一个式子,发现其实是看了zzx代码答案是

(∑i=1⌊n√⌋⌊N/i⌋)∗2−(⌊N−−√⌋)2

BZOJ2749: [HAOI2012]外星人 数论好题。由于我思维能力太弱,看了题解才会做。原问题可以转化为原数经过变化后能产生的2的个数。然后这个东西是积性函数可以用线性筛筛出来。

2016.10.29

AtCoder Grand Contest 006 第一次打AtCoder的比赛,结果两题滚粗了QAQ,第一题字符串模拟,一开始写了一个乱七八糟的模拟结果连样例都没过,赶紧推掉又写了一遍过了。第二题一个数学构造题,我枚举了很多种情况然后发现就是1~2n-1的排列左右移几位得到,在20min左右的时候才a掉。第三题一个奇怪的求期望题,不会QAQ。第四题想了好久都想不出来,Paladin想出正解强行rush没rush出来。第五题第六题不会QAQ。为什么我这么弱啊!什么题都不会。

2016.10.30

AtCoder Beginner Contest 046 果然还是入门比赛适合我= =b。第一题模拟,第二题简单的染色计数,第三题是一个有一点思维难度的贪心,第四题模拟。Paladin说他17minAK的比赛,我做了挺久的果然还是太弱鸡了。

AtCoder Code Festival 2016 qual C 挺好的一场比赛。第一题模拟,第二题贪心,第三题应该也算模拟吧?第四题一个有点思维难度的DP。第五题感觉是一个什么奇怪的康托展开的题?但是不会。。。

2016.10.31

AtCoder Code Festival 2016 qual C E 一整天+第二天的一个早上才搞出来的题。看了题解+看了别人代码+CJK学长的讲解以后才勉强能推出式子来QAQ,果然我独立推式子的能力还是太弱了!!!用树状数组来优化康托展开,然后剩下的都是推式子。一道细节多的题,感觉考场上两版的人都a的题而我想了两天我还真的是弱啊。。。

2016.11.02

埃及分数 一道挺细节的搜索题。迭代加深搜索+上下界剪枝。

2016.11.03

AtCoder Regular Contest 062 E 神奇的组合排列计数问题。枚举两个面,那么整个正方体的八个角的颜色就被确定了。只要查询一下每一个面有多少个满足条件的正方形即可。(注意判有循环节的情况,这样只能放一种)脑洞细节题!!!(做AtCoder的题的时候深深地感受到了:日本人的数学真厉害啊!几场比赛下来难都是数学题。)

[poj1152]矩形面积并 扫描线+线段树。线段树的节点记录这个点被覆盖了几次、被覆盖了的大小是多少。然后每次只要查询一下整个区间的答案就好了。因为这题查询是查询一整段,所以标记可以不用下传,标记永久化即可。(思考:这题能否用更高效的zkw线段树来解决?)

AtCoder Code Festival 2016 qual B A~D 做完几场AtCoder的比赛感觉这里的题都偏向于思维难度以及一些代码实现的细节。AB两题模拟。C题是给一个网格图,然后每一行的纵边和每一列的横边的边权都是相同的,求最小生成树。Kruscal的一个奇怪姿势,找了一个性质就发现过了。D题贪心。(连题目名字都有贪心,题解也是贪心)策略大概就是使得卖出的物品的价格尽量地小,大概就是贡献完答案之后的前缀max+1。E题被同学翻译错题目了QAQ。本来是求一个串的rank,被同学翻译成求k小。。。交了一个trie树的暴力T了12个点卡了一发评测姬QAQ。正解以后(大概是明天?)再写。。。

2016.11.04

AtCoder Code Festival 2016 qual B E Trie树上DP。记f[i][j][k]表示当j字母的字典序在k字母之前时,字典序一定比第i个串小的字符串有多少个。这个可以在Trie上DP来预处理。每次询问的时候处理一下26*26个偏序关系就好了。时间复杂度为 O(总的串长∗26+询问次数∗26∗26) 的。

2016.11.05~11

生病了病了一周QAQ。

2016.11.12~14

学校半期考QAQ。

2016.11.15~18

虽然还在半期考但是数学考挂以后文化课就弃疗了,于是重新开始写题。

15号到18号的做题记录就是把NOIP原题从10年做到07年。题解口胡见上。

NOIP2016考前做题(口胡)记录的更多相关文章

  1. Atcoder/Topcoder 口胡记录

    Atcoder/Topcoder 理论 AC Atcoder的❌游戏示范 兴致勃勃地打开一场 AGC 看 A 题,先 WA 一发,然后花了一年时间 Fix. 看 B 题,啥玩意?这能求? 睡觉觉. e ...

  2. BZOJ 口胡记录

    最近实在是懒的不想打代码...好像口胡也算一种训练,那就口胡把. BZOJ 2243 染色(树链剖分) 首先树链剖分,然后记录下每个区间的左右端点颜色和当前区间的颜色段.再对每个节点维护一个tag标记 ...

  3. ACM之最短路径做题笔记与记录

    在这里纪念一下从4月开始一直因为事情而荒废了的最短路,多亏了jbb的帮助,我才完成了FZU热身赛一题简单的一个用模拟链表存边以及最短路径的学习,目前(6.5)已经学会使用了最简单的djstral与sp ...

  4. [NOIP补坑计划]NOIP2016 题解&做题心得

    感觉16年好难啊QAQ,两天的T2T3是不是都放反了啊…… 场上预计得分:100+80+100+100+65+100=545(省一分数线280) ps:loj没有部分分,部分分见洛咕 题解: D1T1 ...

  5. [日记&做题记录]-Noip2016提高组复赛 倒数十天

    写这篇博客的时候有点激动 为了让自己不颓 还是写写日记 存存模板 Nov.8 2016 今天早上买了两个蛋挞 吃了一个 然后就做数论(前天晚上还是想放弃数论 但是昨天被数论虐了 woc noip模拟赛 ...

  6. BJOI做题记录

    BJOI做题记录 终于想起还要做一下历年省选题了2333 然而咕了的还是比做了的多2333 LOJ #2178. 「BJOI2017」机动训练 咕了. LOJ #2179. 「BJOI2017」树的难 ...

  7. $CH$ $0x50$ & $0x51$ 做题记录

    [X]$Mr.Young's\ Picture\ Permutations$ 前面这儿写了挺多道辣,,,懒得写辣$QAQ$ (后面所有同上都是同这个$QwQ$ [X]$LCIS$ 做过了,看这儿 $u ...

  8. DP 优化方法大杂烩 & 做题记录 I.

    标 * 的是推荐阅读的部分 / 做的题目. 1. 动态 DP(DDP)算法简介 动态动态规划. 以 P4719 为例讲一讲 ddp: 1.1. 树剖解法 如果没有修改操作,那么可以设计出 DP 方案 ...

  9. HNOI做题记录

    算是--咕完了? 2013.2014的就咕了吧,年代太久远了,并且要做的题还有那么多-- LOJ #2112. 「HNOI2015」亚瑟王 发现打出的概率只和被经过几次有关. 于是\(dp_{i,j} ...

随机推荐

  1. python 并发编程 协程 目录

    python 并发编程 协程 协程介绍 python 并发编程 协程 greenlet模块 python 并发编程 协程 gevent模块 python 并发编程 基于gevent模块实现并发的套接字 ...

  2. java--编码规范易漏

    1:命名规范 类名用大驼峰式 参数变量·函数·成员变量·局部变量 小驼峰式 常亮命名全部大些单词用_隔开 抽象类用Abstract开头·异常类用Excetpion结尾·测试类用Test结尾 *POJO ...

  3. springboot笔记之helloworld

    开发工具:IDEA 2019 springboot版本:2.1.9 一.springboot2.x VS 1.x 基础环境升级 最低 JDK 8,支持 JDK 9,不再支持 Java 6 和 7 依赖 ...

  4. dp常见优化方法

    noip范围内的dp优化方法: 加速状态转移 1.前缀和优化 2.单调队列优化 3.线段树或树状数组优化 精简状态 3:精简状态往往是通过对题目本身性质的分析,去省掉一些冗余的状态.相对以上三条套路性 ...

  5. 03、重定义CDF

    有一篇文章“Evolving gene/transcript definitions significantly alter the interpretation of GeneChip data”, ...

  6. 用Kindle阅读PDF最简单的3个方法!

    老实说,Kindle 对于PDF文件是很不友好的,经常会出现各种排版问题,所以,对电子阅读器方面比较了解的同学都知道,如果需要经常用阅读器查看PDF文件的话,最好还是买一款更大屏幕的设备,而Kindl ...

  7. jQuery jsonp跨域请求详解

    跨域的安全限制都是对浏览器端来说的,服务器端是不存在跨域安全限制的. 浏览器的同源策略限制从一个源加载的文档或脚本与来自另一个源的资源进行交互. 如果协议,端口和主机对于两个页面是相同的,则两个页面具 ...

  8. 运维nslookup语法

    nslookup 查询域名DNS信息的工具 补充说明 nslookup命令 是常用域名查询工具,就是查DNS信息用的命令. nslookup4有两种工作模式,即“交互模式”和“非交互模式”.在“交互模 ...

  9. Python爬虫之定时抢购淘宝商品

    Python爬虫之定时抢购淘宝商品 import time from selenium import webdriver import datetime class Spider: def __ini ...

  10. 2>&1的含义解释

    某次想将adb的help信息保存起来 F:\android系统\AndroidTool_Release_v2.\bin>adb >help.txt 结果 F:\android系统\Andr ...