Day 0

一番纠结之后,我还是选择了 PKUSC (Penguin Kingdom University Summer Camp, 企鹅王国大学夏令营)!

理由?扔硬币决定的理由如下:

  • PKU好啊
  • PKU放出初审名单时间比THU结束报名确认时间还晚……大概有点想去THU的这样一来就全去THU了?去PKU的人就少了?
  • THUWC的心理阴影 = =

于是开心地通过了初审,在真·教练员的陪同下第四次来到了北京。

北京好热啊!大连真是一个冬暖夏凉的好地方,以后到北京上学被热死可怎么办啊(你tm先考上再说吧)

住在PKU西南的一个小酒店,一个人住标间,房间超级小(小得让我想到CTSC的珀丽酒店),过道连个箱子都放不下……一个床用来放箱子一个床用来放自己刚刚好2333

放下箱子就去找SCaffrey学长辣!(企鹅学长对我能见到他心爱的学长这件事表示羡慕 =v= )然鹅SCaffrey在上课……遂一个人在PKU溜达。这是我第一次进北大,虽然在地图上鸟瞰觉得PKU比隔壁小,但是实际上似乎……并不小的样子?迷路好多次TAT

在一个地下咖啡厅做了一个小时的 Jewish Problems 数学题,发现自己什么都不会做……

在西北角我发现了鸭子!一只大鸭子和n只毛茸茸小鸭子在一块石头上休息……我走近鸭子们也不怕我( •̀∀•́ ),于是我就近找了个椅子坐着优哉游哉看鸭子——半个小时后我发现有蚂蚁正在我腿上往上爬……把蚂蚁抓下来后,我连忙离开了鸭子们,去找差不多下课了的学长了。

24OI一代传说SCaffrey学长带着我看了一下机房的电脑……对用的是Windows而且有Vim没Emacs的电脑表示震惊……在蹭了学长两顿饭……农园二楼还是很可吃的……(可惜后来发现pkusc卡不能用来刷农园二楼)

下午是报到,SCaffrey学长说他当年第一个去报到然后拿到了降60,于是我也去第一个报到了!要是也能降60就好了……

Day1

Day1上午是万恶的数学考试!怀揣着“数学考试影响不会很大吧”的自我洗脑心态,十道题我做了六道题的样子……其中有一道还是昨天做的 Jewish Problems 里的原题,据说前几年还考过这道题?

考完数学觉得对于我这样的数学菜鸡来说做出这些已经很不容易了,于是开心地吃了午饭,到机房门口准备参加下午的机试。

T1

题意大概是:有N个人,每个人有各自的成绩(非负整数),选出K个人使他们成绩变成原来的两倍,问对于每个人,有多少种选法中他的排名和原先的排名一样。N记得是1e5还是1e6的样子?

看起来是一道非常可做的题啊!对每个人分类讨论他自己选没选,没选的话要从选后不影响它排名的人中选K个,选了的话设排名减少了C,要从选后影响(乘二后的)它的人中选C个,再从不影响(乘二后的)它的人中选(K - 1 - C)个。

于是我愉快地写完了。交上去WA好多。很久以后发现数据中会有人成绩是0。特判后终于AC。成功耽误1h。

T2

给一个长为N的序列,问随机打乱后最大前缀和的期望,N <= 20

这啥玩意啊?稍微冷静想想后发现\(O(n3^n)\)的做法我会,加上两个特判点能得60分……一直想想出正解……没想出来……

T3

啥?主斗地?斗地主?又双叒叕是斗地主?现在的OIer是不是只有我一个人不会斗地主了?

由于看到九条可怜+斗地主感到过于害怕、且对斗地主一无所知、且连第一个包的性质都没有发现,遂爆零之。

考完发现我好菜啊!开考2h之后啥都没干!似乎大众分是230……我比大众分少70……感觉要没约滚粗了!

郁闷地吃完饭回去颓了。C君更新的实况还是要看的 = =

Day2

考试这两天睡得都莫名不错……

今年不知为什么面试安排在第二场机试前面!我这种菜鸡也可以告别【没进面试】的绝望啦!

面试分三场,在不同的房间,面试官是不同的人……

第一场

闲聊……面试官很和蔼,自我介绍我吹了一通牛逼,我说我会画画,然后面试官问我现在手里有没有能给她看的,我打开手机第一张图是《明明是我先来的》(THU vs PKU版),然后就不敢把手机给面试官了 ><

第二场

又是闲聊……面试官说:“刚才有个选手跟我说D类名额,什么是D类名额啊?”我解释了一下,然后面试官又问“那什么是C类名额啊?”迷啊……剩下的时间面试官都在和我谈“学竞赛的女生很少啊”“你觉不觉得吃力啊”“你觉得男生和女生思维上有什么不同啊”……我日常吹一波我辽宁三大老爷们的故事 =v=

第三场

还是闲聊……面试官问我“你之前怎么没有签过约啊?”“你要是这次没签到的话有什么打算啊?”问得我很惶恐。然后面试官又问我昨天考多少分,我说160,面试官说“哦……”。最后我着急地说:“老师,我很希望能够抓住这次宝贵的机会……”面试官:“哦,我也希望你能。”好慌啊……

为什么都是闲聊啊?为什么感觉给我面试的老师没有几个是信息老师啊?听别的选手说还有问恋爱情况的……还有给你张纸让你画个画的……还有让英文自我介绍的……还有个别问学术问题的……

吃完饭看时间还早,在PKU一处长椅上躺了一会。不知道睡没睡着,但是被蚊子咬了三个大包。

然后就是决定命运的第二场机试了!

T1

有\(n\)个点,第\(i\)个点向\([L_i, i - 1]\)的所有点连长度为1的无向边,保证\(L_i \le i - 1\),有\(q\)个询问,每次给出\(l, r, x\),问\(x\)到\([l, r]\)中各个节点的最短路之和。

本来觉得应该挺可做的的吧?然后想了半天想不出来,只找到一个小性质——从\(u\)到\(v(v < u)\)的最短路上,u最多只向右走一次,而且这一步的终点是“所有向右一步能到达的点中\(L\)最小的”(下文提到时记作\(R_i\)。

有一个\(O(n ^ 2)\)的暴力,没有想出来……又去看了看T2,毫无思路,回来下定决心把T1暴力写了,然后发现刚才想的一个思路就差一步,很快把这个70分暴力写出来了。做法大概是\(f_{i, j}\)表示\(i\)到\(j\)的最短路\((i \le j)\),如果所有的边都是由右向左的单向边,\(f_{i, j} = 1 + \min_{k = L_i}^{i - 1} f_{k, j}\),用一个单调栈维护后缀最小值,然后就可以\(O(n^2)\)预处理这种情况下所有最短路了。然后再对每个点考虑第一步向右走了的最短路,就是\(f_{i, j} = \min (f_{i, j}, f_{R_i, j})\)。然后就可以\(O(1)\)回答询问了。

然后想搞正解,没有思路……

T2

有一个字符串,由'0'、'1'、'?'组成。'?'可替换成'0'或'1'。称一个数\(x\)是字符串的border当且仅当字符串的x长度的前缀完全等于字符串x长度的后缀。问有哪些\(x\)经过对'?'的替换后可能成为border。

写完T1暴力后T2也找到了一个性质。当\(x \le \frac{n}{2}\)时似乎很可做,分别比较前面的1是不是对应到了后面的0、前面的0是不是对应到了后面的1即可,这个用FFT能做到(就是一个数组把是1的位置设成1,另一个把是0的位置设成1,卷积一下,某一位对应的不是0则说明有矛盾。之后再反过来做一遍)。

当\(x > \frac{n}{2}\)时,发现这个“前缀”与“后缀”有重叠,设\(k = n - x\),即前缀向右平移了\(k\)个字符成为了后缀。则位置\(i\)的字符与位置\(i + k, i + 2 * k, …\)的字符都要相等,发现只要\((i - j) \bmod k = 0\)就要满足i的0不能对应j的1、i的1不能对应j的0。于是FFT一边,对于每个\(k\)枚举\(k\)的倍数——\((i - j)\),即可判断是否合法。

先用这个性质写了发暴力,交上去过了暴力点,然后放心大胆写正解,A啦!(A之后上了趟卫生间,走路姿势都变拽了……)

T3

计算几何?!

写了半天,交上去,爆零。调不出来。再见。

第二天也结束啦!似乎发挥得比第一天要好一点……虽然还是赶不上dalao们口中的“大众分”……

Day3

闭幕式了,非常忐忑,这天早上是唯一一天没一觉睡到六点的(也有可能是蚊子包太痒了)。

听了讲题,有点心不在焉,很多地方没听明白,不知道什么时候能把题放出来我再研究研究。想起吉丽出的两道题我都爆零了,难受啊……(“有人得分的题就是区分度好的题”——吉丽)

终于开始念名单了,忐忑地听了能有二三十个之后,居然念到我了!我当场大喊一声“卧槽!有我!”便挤出去拿约。

约上写了好多字……真·教练员突然出现(我之前没有看到他……),告诉我这是无条件降60的意思。当时觉得心里的石头终于落了地了。NOI考前100还可以降一本,努力吧!

总结?

第一次签到约……结束了两千多年的封建帝制结束了半年来的“没学上”的忐忑不安……可以更专心地准备NOI了。

听说THUSC特别可怕,辽宁全军覆没了啊……心疼学姐、高大佬、薛大佬他们……(反正他们这么强 NOI会Au的吧)

加油加油咯!

胡小兔的 PKUSC2018 游记的更多相关文章

  1. 胡小兔的NOIP2017游记【出成绩后更新版】

    胡小兔的NOIP2017游记[出成绩后更新版] 2017.11.22 Update 前几天成绩出来啦,看这篇博客访问量还挺多的,下面就分享一下结果吧: 我的Day1T2和Day2T1两道最水的题都跪了 ...

  2. 胡小兔的OI日志3 完结版

    胡小兔的 OI 日志 3 (2017.9.1 ~ 2017.10.11) 标签: 日记 查看最新 2017-09-02 51nod 1378 夹克老爷的愤怒 | 树形DP 夹克老爷逢三抽一之后,由于采 ...

  3. 小兔的棋盘(hdu2067)

    小兔的棋盘 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  4. 小兔伴伴家庭动物园AR智能早教产品上市

    2016年6月,经过乐卓大家庭所有人的共同努力,公司旗下首款新品——小兔伴伴之<家庭动物园>3D智能学习卡正式面世. 每个孩子都应该在合适的时间去体验丰富的声音.色彩和动作,<家庭动 ...

  5. HDU 2067:小兔的棋盘

    小兔的棋盘 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  6. 递归:这帮坑爹的小兔崽子 - 零基础入门学习Python023

    递归:这帮坑爹的小兔崽子 让编程改变世界 Change the world by program 斐波那契数列的递归实现 这节课我们用斐波那契(Fibonacci)数列的递归实现来作为第一个例子吧,斐 ...

  7. javascript基础(幼兔、小兔成兔数量等典型例题)

    一张纸的厚度是0.0001米,将纸对折,对折多少次厚度超过珠峰高度8848米var sum=0; var a=0.0001 for(var i=0;i<100;i++){ a=a*2; sum= ...

  8. 小兔的棋盘(hdu2067)

    小兔的棋盘 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  9. HDU 2067 小兔的棋盘 (卡特兰数)

    小兔的棋盘 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

随机推荐

  1. mybatis-高级结果映射之一对一

    mybatis的高级结果映射可以很轻松的帮助我们处理一对一, 一对多的数据关系. 1 数据准备 1.1 数据库 创建以下的名为 mybatis 的数据库, 并在其下创建4个表. 在此就不贴出来建表的 ...

  2. 001_IntelliJ IDEA详细安装步骤

    安装IntelliJ IDEA 一.安装JDK 1 下载最新的jdk,这里下的是jdk-8u66 2 将jdk安装到默认的路径C:\Program Files\Java目录下 二.安装IntelliJ ...

  3. iphone忘记锁屏密码却记得appleID密码的不保存数据的刷机办法

    请注意看清题目再看本文,另外一切后果博主不负任何责任.操作实现环境:原装数据线,拔掉sim卡昨天,iPhone6sp忘记密码被锁定,尝试通过找回手机抹除手机功能后,提示需要手机接入互联网才能实现,而我 ...

  4. 金蝶PDA金蝶盘点机金蝶仓库条码管理方案-采购入库单教程

    采购入库单有两种做法: 第一种:按照采购订单下推的采购入库单. 第二种:直接新增采购入库单,也就是不按照采购订单下推. 按照采购订单下推生成采购入库单,会以采购订单的商品品种和数量作为应收.扫描条码入 ...

  5. mongo java 踩坑记

    为什么会有这么多坑 1.  Java会把 id:String = "合法ObjectId"  好心好意的 转为  _id:ObjectId 类型. 2. 为了避免第1点, 我定义了 ...

  6. 不重叠的线段 51nod

    链接 [http://www.51nod.com/onlineJudge/questionCode.html#problemId=1133&noticeId=468024] 题意 X轴上有N条 ...

  7. 《Linux内核分析》期终总结&《Linux及安全》期中总结

    <Linux内核分析>期终总结&<Linux及安全>期中总结 [李行之 原创作品 转载请注明出处 <Linux内核分析>MOOC课程http://mooc. ...

  8. Linux内核分析第八周总结

    第八章 进程的切换和系统的一般执行过程 进程调度与进程调度的时机分析 第一种分类: I/O密集型(I/O-bound):频繁的进行I/O,通常会花费很多时间等待I/O操作的完成 CPU密集型(CPU- ...

  9. Selenium Grid的Java调用方法

    java -jar selenium-server-standalone-.jar -role hub explorer http://192.168.1.173:4444/grid/console ...

  10. multer处理post请求的代码演示

    let express = require('express'); let multer = require('multer'); let mObj = multer({dest:__dirname+ ...