第一次写比赛游记,请多多指教!

I. 考前

由于最近参加了太多太多比赛了,所以没有敲模板题;

考前一周:主要是在做 AtCoder 的题和 xjoi 的模拟赛,相当于恶补了一些套路吧!

考前一天:上午狂写 agc,下午的时候才想起来不应该这么劳累(借口),遂开始颓废——借着试机的机会带着班上其他的同学一起逛了逛校园;一回机房发现嬴政大佬和小粉兔大佬居然在我电脑前面看我的 AtCoderProblems,感觉有大神祝福一定会考好的!

考前 30 分钟:居然要等到开考才能进考场,差评差评!害得我提着两瓶可乐在教室门口等了这么久(但是我是这件考室第一个进场的,好吉利!

考前花絮部分:

  1. 谢队的精准预言(本人已内牛满面

谢队:"Windows 下问一个经过了一系列操作的小数是否和整数相等,Windows 下会告诉你 Yes,Linux 下可能不会;"

谢队:"Windows 可能连分数类都替你写好了,而 Linux 就没有那么智能。"

  1. 监考老师看见林祺昊同志,不解地问这么小的选手来考个啥子呀

我:"您别看他小,他上次 CSP 成绩是我的三倍呀!blablabla……"

考官:"那你来考个啥子呀?"

我:…………

  1. 考前一天的那个集体颓废的下午,小粉兔难得地出现在机房疯狂 fAKe

兔队:"哇这是什么题哇!强啊!这都是什么神仙题啊!我c!我输了~"

一众人 & wo:"@%……#¥&¥@&@%¥@%……"

  1. 考前几天下午放学后固定在操场和一本校高一 CMO 国集队爷畅谈人生

队爷:"我本来只想稳稳地拿下 T1、T4 的,结果,12456 全做出来了……"

顿时感觉这次考试应该稳稳地打,就稳住 T1 好了。


II. 好的开端

通读了一遍题目,感觉第一题拓扑一下就能做,第二题字符串很意外,第三题感觉没思路,第四题有点读不懂,先丢掉回头再来读题。

T1: 真的开始写的时候发现居然是分数形式的输出,掐指一算,\(5! = 120\),数最大是 \(120^{10} = 619,173,642,240,000,000,000\),爆 ll !刚开考嘛,心态比较稳定,所以很冷静地先假设只要输出小数,把拓扑排序写了一遍,大概花了 5 分钟这样吧;其中感觉拓排中有些点度数不会减到 0 这可真是个大大大大大坑点,还好有上次的《函数调用》作为铺垫~

T2: 调和级数这个太容易一眼看出来了,想了想这个 \(F(A) \leq F(C)\) 的要求可以用树状数组来统计,于是一顿写,20min 写完了,花了 30min 来调试,主要有三个问题:

inline unsigned int subhash(int l, int r) { return hash[r] - hash[l - 1] * fac[r - l + 1]; }

这个函数,一段时间没打字符串哈希的我居然写成了:

inline unsigned int subhash(int l, int r) { return (hash[r] - hash[l - 1]) * fac[n - r + 1]; }

好后悔考前一天在 2020 国集作业里看到的那道哈希题居然没有去写一写。还有一个错误是没有考虑到 \(AB\) 段可以随时结束,并不需要延伸到尽头,这个错花了我更多时间!

当然这题还犯了两个错误——没卡时和没有开双哈希。

III. 失误的发生

**T3: ** 天真的我以为这题可做,想了个挺复杂的做法,以为就行了,30min 怒码 3KB,一发样例 RE,猛然发现有那么一种情况下这个有问题,偏偏是这最后的问题,偏偏解决不了,当场自闭,看着右手边的 hjh 大佬沉着的样子,更加的恐慌。又想了 15min,果断开 T4。可以说这个事大大消耗了我的脑力,也为 T1 的失误埋下了伏笔。

T4: 想了个 40pts 做法果断跑路。

T1: 真正的失误 。高精度?不会!不会!但是我会 long double!索性,把过程中的每个数都乘上最大分母 \(619,173,642,240,000,000,000\),虽然有点大,但是我可以用 long double 艹过去!

想起了谢队昨天的 ** 忠告 ,我测试了一下 long double 在这个事情上的精度,发现这么大的 long double 在除以 \(degree\) 和权值相加后居然误差极其之小,就是我想要的效果! 于是走上了聪明反被聪明误的不归之路 **!

前面当然都很顺利,但是到了输出的时候出了问题——我该如何判断它是否整除一个数呢?那我索性先除下去看看结果是不是整数呗!然后奇迹发生了,它告诉我,\(120^{10} / 7\)是整数!!!整数!输出出来,得到了如下的结果:

\(120^{10} / 7 = 88,453,377,462,857,142,856\)

居然真的是整数!!!我当机立断,既然误差这么大,那么我判断一下这个数除完后的商再乘以除数即可啦!然后用 C++ 一输出,人傻了!

\(88,453,377,462,857,142,856 \times 7 = 120^{10}\)

谁都看的出问题,猛然想起来谢队前一天说的——Windows 可能连分数类都替你写好了,而 Linux 就没有那么智能,然后整个人都懵了。

IV. 运气之神的眷顾

情急之下去了趟 WC,点名批评时代中学的厕所布置!一路走下去全是女厕所,找了半天的男厕所……最后还在厕所遇到了 Zenislt 大佬,他说他和 c03 同时写完了 T1,当场又崩溃了一次。

回来之后,突发奇想——我可以分成 5 的负多少次方分别存一个 dp 值,这样从头到尾只有输出是超过 long long 的!写了半天,发现大样例炸了,此时离考试结束只有半小时。

心态已经彻底凌乱了,简单地检查了 T2、T4 之后就扎进了调试里,硬是调不出来!考试结束前 5min,乱码了一些东西,过了大样例,出了考场,内心是一片空白的。

没想到,就是最后 5min 的挣扎,使得 T1 在民间数据获得了 100 分至 90 分不等的分。

V.考后

出了考场,遇到了两位大神学长——谢队和宏队,我赶忙疯狂膜拜~然后谢队说了下面这段话:

"平时单元考考得很好的人,大考不一定会考得很好,懂了吗?懂了吗?"

我:一脸懵逼.jpg,完全不懂大佬在所言指的是什么。

然后学长们开始给学弟讲鬼故事——T1 是前 \(m\) 个点是源点、T2 你单模数哈希还有两个 log 怎么可能过、T4 这个一眼就应该想出 80pts 的……

我:当场自闭.jpg,觉得自己完全炸了。

民间测试数据测完之后感觉稳得多了,T1 居然拿下了绝大部分分(oituku 100pts),T2 洛谷上能跑 96pts!加几个 register 就能过。

VI. 教训

T1 这种题,大家都不开高精 = 大家都开高精,不要想太多,就写一个普通的用 ll 的分数的 struct 就行了,哪有那么麻烦?考场上我还是不会取舍啊!

T2 哈希一定要开双哈希啊,虽然民间数据能过,但是心里还是虚啊!而且一定要卡常!不要一到正式考试就连快读都不写了!

T3 我还是缺乏识别不可做题的能力!

T4 这个是主要的区分度,我还是太菜了,想不出 80pts 做法;同时打 40pts 做法是个大大大大错误,应该打 30pts 那档,不容易错!害得我这题洛谷上只有 5pts!

NOIP 2020 游记的更多相关文章

  1. 「NOIP 2020」微信步数(计数)

    「NOIP 2020」微信步数(Luogu P7116) 题意: 有一个 \(k\) 维场地,第 \(i\) 维宽为 \(w_i\),即第 \(i\) 维的合法坐标为 \(1, 2, \cdots, ...

  2. noip 2018游记

    憋了好久的游记... 考虑到写游记是oi界的传统,所以还是应该写一篇的. day0: 上午9:30的火车出发,车上颓三国杀! 中午12:00到了大连,下午2:00才开始试机,还是得先去大连大学,在食堂 ...

  3. 开始是为了结束,结束是新的开始——NOI 2020 游记

    Day 0 报道日 晚上的时候我们的教练给我们做考前动员.给我们讲:NOI的五个小时需要认真的规划,不能被T1打乱节奏.他让我们思考明天的策略,把可能出问题的地方都想清楚. 结果后来,宿管给我测体温, ...

  4. CSP-S 2020 游记

    2020.10.11 初赛了,没怎么做题,之前在网上两次初赛模拟赛 95pts / 94pts,还白嫖了一本书,感觉挺好. 去考场,中途不舒服去了厕所,回来发现有点来不及,阅读程序最后两题不会瞎蒙. ...

  5. 【杂记】CSP-S 2020 游记 &反思

    考场经历 吐槽:为什么这个 Enter 的位置怎么诡异啊老是打错.要是考挂了就怪你 开场当然先看了 T1,发现是个日期转换,果然是个百出不厌的模拟题类型,估价细节多到爆炸.看了几分钟题目,对这些规则云 ...

  6. NOIp 2020

    游记 Day-1 我已经开始慌了. 不知道前路如何.不想回文化课.唯一一次机会,可是这几天却一直在颓,不颓就慌. 没心思写题,导致这几天看的题啥都不会.不知道考试当天又会出什么幺蛾子. 啊啊啊,烦. ...

  7. NOIP 2015 游记

    本来和zly和wxh约好了 高三一起再来玩一次复赛,结果最终只有我一个人来了说...貌似是年段主任不让去...总算见识了比我们学校的YSD更爱管闲事的年段主任. 今年比赛竟然在衢州二中,学校不大,但感 ...

  8. NOIP 2017 游记?

    Day -1 晚上被dg谈了谈人生,没有卵用 Day 0 早上又被老吕教训了一遍,想打板子,打印机还坏了,老吕又奶了一波题,后来发现一个都没中.之后就出发了,中午吃了点肯德基,妈妈来了,给我了个小袋子 ...

  9. NOIP 2019游记

    Update on 2019.4.20 禁赛预定

随机推荐

  1. 小白自制Linux开发板 七. USB驱动配置

    本文章基于https://whycan.com/t_3087.htmlhttps://whycan.com/t_6021.html整理 F1c100s芯片支持USB的OTG模式,也就是可以通过更改Us ...

  2. 【UE4 C++ 基础知识】<12> 多线程——FRunnable

    概述 UE4里,提供的多线程的方法: 继承 FRunnable 接口创建单个线程 创建 AsyncTask 调用线程池里面空闲的线程 通过 TaskGraph 系统来异步完成一些自定义任务 支持原生的 ...

  3. python打印爱心

    print('\n'.join([''.join([('AndyLove'[(x-y)%8]if((x*0.05)**2+(y*0.1)**2-1)**3-(x*0.05)**2*(y*0.1)**3 ...

  4. UltraSoft - Alpha - 测试报告

    遇到的bug bug:在vue.config.js里配置proxy,并修改请求的url后仍无法连接到后端. 解决: url最后忘了'/',导致和后端不匹配,会有404.500等错误. 后端服务未打开或 ...

  5. NGINX杂谈——flask_limiter的IP获取(怎么拿到真实的客户端IP)

    本篇博客将 flask_limiter 作为切入点,来记录一下自己对 remote_addr 和 proxy_add_x_forwarded_for 两个变量.X-Real-IP 和 X-Forwar ...

  6. 数列极限计算中运用皮亚诺Taylor展开巧解

    这是讲义里比较精华的几个题目,今晚翻看也是想到了,总结出来(处理k/n2形式). 推广式子如下: 例题如下:

  7. 51nod_1001 数组中和等于K的数对(二分)

    题意: 给出一个整数K和一个无序数组A,A的元素为N个互不相同的整数,找出数组A中所有和等于K的数对.例如K = 8,数组A:{-1,6,5,3,4,2,9,0,8},所有和等于8的数对包括(-1,9 ...

  8. 极速上手 VUE 3—v-model 的使用变化

    本篇文章主要介绍 v-model 在 Vue2 和 Vue3 中使用变化. 一.Vue2 中 v-model 的使用 v-model 是语法糖,本质还是父子组件间的通信.父子组件通信时有两种方式: 父 ...

  9. robot_framewok自动化测试--(1)Robot Framework 环境搭建及常见日志问题解决办法

    一.Robot Framework 介绍 Robot Framework 的架构是一个通用的验收测试和验收测试驱动开发的自动化测试框架(ATDD).它具有易于使用的表格来组织测试过程和测试数据. 它使 ...

  10. msfsploit框架的使用——ms17_010漏洞的利用

    开门见山,首先输入msfconsole打开msf控制台 全球最牛逼的渗透测试框架就是长这个样子(每次打开时,显示的图案都不一样) 然后搜索ms17_010的相关模块,得到了六条结果,我们需要用的是编号 ...