[搬运自 qq 空间] 19 联赛小结

news/2025/1/30 7:52:58/文章来源:https://www.cnblogs.com/evenbao/p/18695033

19联赛小结
用一篇流水账纪念一下这次比赛。
11.15 Day0
经过两个小时的车程 , 终于来到了南京
阳光洒在南航主楼上 , 泛起点点金光。
这已经是我初中第三次来南京比赛了 , NOIP也因政策原因被迫改名为CSP , 三年以来 , 发生了太多太多的事 , 心中不由感慨万千。
上午做了几道codeforces上的题 , 将一些不太熟练的代码又敲了一遍 , 晚上从宾馆7楼爬到18楼和PCF , CZY几个高一的大佬玩了一会 , 明确了一下明天比赛的策略 , 十点就睡觉了。
11.16 比赛日 Day1
夜里醒了很多次 , 不过精神还可以 , 并没有像去年那样萎靡不振....
提前半个小时到达南航操场排队 , 和本校的几个大佬谈笑风声了一会就进机房了。
试机的时候把模板写了 , 确认了电脑没有问题 , 过了一会试题就下发了。
做了个深呼吸 , 开题!
先看T1 , 发现这是个比较简单的模拟题 , 只需要枚举二进制位一位一位分治下去就行了。 我很快就把这题做完了 , 通过了所有样例。 这时我看到了对于95%的数据 k <= 2 ^ 63 - 1 , 对于100% 的数据k <= 2 ^ 64 - 1。 这个限制有什么用? 我想了想好像没啥用就不管了。 万万没想到这造成了我之后的半个月每天都追悔莫及。
再看T2 , 发现这是一个树上的计数题。 看到括号序列 , 我很快想到了把左括号看成1 , 右括号看成-1 , 然后只需要在深度优先遍历的时候用可持久化线段树维护就行了。 仔细想了一下 , 发现并不需要这么复杂 , 只需要对于每个结点维护一些信息 , 在DFS的时候实现可回退就行了。 这样做的复杂度是线性的。 在9 : 15的时候我完成了这个程序的调试 , 测了一下第三个样例 , 发现运行错误。 我顿时惊出一身冷汗 , 通过测试 , 发现南航的机器只允许进行30000次递归。 一开始 , 我认为程序到北京测试时会开大栈空间 , 但觉得不测第三个样例太虚了。 斟酌了一番 , 决定还是手写栈模拟递归。 在此之前我从未这样写过 , 因此一开始以为这需要花费大量的时间 , 没想到我在15分钟内就修改完毕 , 完成了调试。
此时我已经拿到了200分 , 上个厕所冷静了一下 , 回来思考第三题的解法。
T3又是一道关于树的题 , 这题的N最大只有2000 , 开始时我想出了一个贪心的算法 , 兴冲冲地写 , 结果一个小时后发现这个是错的 , 当中还断断续续想出了其它做法 , 不过也一一被否决了。 时间只剩下了一个小时 , 怎么办? 我不由乱了阵脚。 先去写了一条链的部分分 , 没有成功 , 又去写菊花图的做法 , 也没有成功 , 最后只写了10分的暴力分 , 此时的我才意识到策略的失误 , 不应该强攻满分算法 , 然而已经为时已晚 , 我开始疯狂调试一条链的部分分 , 渴望着奇迹的发生。 然而并没有奇迹 , 我最终还是没有完成这档部分分的调试。
考试的时候后面的南外大佬不停地敲键盘 , 于是在比赛后问了一下他的估分 , 得知他第三题也只有10分 , 然后又问了常中的jyg , 得知他也只有10分 , 这才知道今天的第三题难度非常大。
day1估分100 + 100 + 10 = 210
下午去初中组玩 , 发现试题非常简单 , 10分钟做出了前2题 , 两个小时的时候做完了4道题。
通过喝水 , 吃东西 , 上厕所 , 思考人生等方式消磨时间。 一个半小时后比赛结束了。
晚上和合肥四十五中的老朋友lmb交流了一下 , 得知他第二题挂了 , 无望翻盘。 或许这就是OI吧 , 然而他还不是最惨的 , 今天结束后已经有很多高二的Oier将要回归文化课 , 迎接高考 , 明天又会有很多人。 就像人生一样 , 总有人留下 , 也总有人离开。这也正是这条路的残酷性。
11.17 比赛日 Day2
早上和几个南外的聊了会天 , 得知他们昨天估分也都是210分。 然而djq神仙把第三题做出来了 , Orz!
8 : 00进考场试机 , 发生了这样的一件事情 , 旁边的选手不能调试 , 却被告之工作人员只管linux系统下的问题 , 不管windows的 , 数次举手示意均被拒绝 , 且考官拒绝更换座位。 这使我感到有些愤怒 , 但也有些庆幸自己没有被分到他的座位上。
8 : 30 , 比赛正式开始。
我先把三题都读了一遍 , 发现今天的试题明显变难了。 但部分分并不是很难拿。 我还是决定以1,2,3的顺序开题
T1是一道计数题。 我思考了20分钟 , 仍没有思路。 后面的南外大佬已经开始敲键盘了 , 我不由有些紧张。
又过了一会 , 我突然想到题目中的第三个限制非常特殊 , 不满足要求的数最多只有1个 , 因此可以容斥 , 用总数 - 不合法数。 这两者都可以动态规划求出 , 只需做M次即可。 预处理每一行数的和就可以做到O( 1 )转移 , 这样做的时间复杂度是O(N ^ 3M)的 , 可以拿到84分。
考虑到这个做法能拿到这题的大多数分数 , 再加上强烈的得分欲望 , 我用10分钟写完了这个程序。
再看T2 , 36分直接O(N ^ 3)动态规划就行了 , 于是我先写了这一档部分分 , 然后思考64分的做法 , 我发现36分做法中的动态规划是可以用数据结构优化的 , 于是写了个动态开点线段树 , 却一直没通过样例。 在调试的时候我发现并不需要线段树 , 直接树状数组维护就行了。 然后又发现它甚至连树状数组都不需要 , 只要记录后缀最值 , 就可以实现O(log N)的转移
我完成这个做法的调试时已经过了很长时间 , 我先想了一下这题的88分做法 , 感觉就是要推出一些性质 , 然后用数据结构 / 决策单调性 / 单调队列之类的东西优化一下。 然而我并没有具体的思路 , 考虑到时间已经过半 , 决定先看T3
T3的40分就是枚举删边 , 对于两棵子树分别求树的重心。 我先写了这一档部分分。 然后发现第二档部分分也比较好做。 只需将这条链记下来 , 然后求中位数就行。 没想到我因为程序里漏打了一个return调试了很久。 导致只剩下了20分钟。
这时我决定保险起见 , 反复检查了文件 / 程序大小 / 数组越界 / 空间超限等问题。
最后5分钟 , 我想出了第一题的正解。 然而已经来不及了。 非常难受 , 思考了一下人生。
估分84 + 64 + 55 = 203
出考场问了一下不同人的得分 , 今天的试题区分度很大 , 有高手拿了250+的 , 也有100+的 , 还有没考到100分的 , 然而我校选手只有3人超过150分。
回来的路上突然想起d1t1 n = 64的情况我是全错的 , 最低只有50 , 于是在担心中度过了2个星期 , 好在出题人没有***难我 , 最后只给了一个n = 64的数据。
[成绩]
我的最终得分是95 + 100 + 10 + 84 + 64 + 55 = 408分 , 排进了江苏省前40 , 拿到了常州初中生中的第一 , 并且也基本拿到了北大冬令营 , apio , ctsc的资格。
刚开始有些开心 , 然而仔细想想觉得也没什么 , 前方还有很长的路要走 , 我与高手间也还有较大差距 , 况且这次比赛我也没有发挥到最好 , day1的失误和day2的过于保守都使我吃了亏。
[总结]

  1. 多做codeforces , poi , agc的题 , 提升思维能力
  2. 多阅读经典书籍 , 多读国家集训队论文
  3. 提高程序的一次正确率
  4. 多学算法 , 多做题
    [写在最后]
    "长夜漫漫 , 愿你我能摸黑赶路 , 亦能发亮如星"。 愿自己 , 继续努力 , 不辜负心中梦想的声音 , 在这条路上走的更远。
    愿天下所有的Oier们都能有光明的未来。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/877003.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[搬运自 qq 空间] 19 北大冬令营小结

PKU 冬令营19北大冬令营小结 北大冬令营刚刚结束 , 以下是这两天以来笔者的经历。 Day1 比赛日 上午开营仪式 , 整个过程大概就是讲了一下北大计算机学科有哪些优势 , 比较无趣。 12 : 40的时候来到机房准备考试 , 1 : 00钟时 , 比赛正式开始。 首先浏览了一下A题 , 是吉…

X3ctf 比赛 Write Up

X3ctf Write Up 1. Misc p11n-trophy(签到题): 题目描述:我们首先会得到这样一份证书:第一题签到题的答案就是证书下面正中间的“This certificate does not grant the rank of Master"。 trophy-plus + trophy-plus64: 这两道目描述一模一样其中一个flag是藏在certif…

python--用户意见

https://www.python.org/about/quotes/

虚拟记账系统之三种结算模式

虚拟记账系统作为近年来支付领域的创新产品,正成为企业资金管理和支付结算的重要工具。本文从支付断直连的背景出发,详细介绍了虚拟记账系统的三种结算模式:收单结算、归集直清和归集调拨,并深入探讨了这些模式在直播电商、企业资金管理等场景中的应用。从这篇文章开始,我…

RocketMQ实战—2.RocketMQ集群生产部署

大纲 1.什么是消息中间件 2.消息中间件的技术选型 3.RocketMQ的架构原理和使用方式 4.消息中间件路由中心的架构原理 5.Broker的主从架构原理 6.高可用的消息中间件生产部署架构 7.部署一个小规模的RocketMQ集群进行压测 8.如何对RocketMQ集群进行可视化的监控和管理 9.进行OS内…

Web 前端开发

通俗来说, Web 前端开发就是开发前端网页程序. 前端网页程序主要负责的就是将数据以好看的形式呈现出来. 网页有哪些部分组成: 文字、图片、音频、视频、超链接、表格... 前端的代码是如何转换成用户眼中的网页的: 通过浏览器转化 (解析和渲染) 成用户看到的网页. 浏览器中对代…

【 Github 】 如何获取 Github 上最新的 release 文件

前言 在 Github 上,我们经常会看到一些开源项目会发布 release,这些 release 文件通常是一些二进制文件或者压缩包,我们可以通过以下步骤获取到这些文件的最新版本。 1. 打开 Github 项目页面,查看最新的 release 版本 首先,我们需要打开 Github 项目页面,例如:https://…

【开源】gocron:一款开源可视化定时任务管理系统

在数字化转型的浪潮中,定时任务管理系统作为保障业务连续性和自动化运维的重要工具,扮演着举足轻重的角色。然而,传统的Linux-crontab等工具因其复杂的配置和有限的灵活性,难以满足现代企业和开发者对高效、用户友好任务调度的需求。正是在这样的背景下,Gocron应运而生,它…

【数据库】DrawDB:超好用的,免费数据库设计工具

引言 在软件开发过程中,数据库设计是一个至关重要的环节。 无论是关系型数据库还是非关系型数据库,良好的数据库设计都能显著提升系统的性能和可维护性。 然而,数据库设计往往伴随着复杂的表结构和关系,如何清晰地表达这些设计成为了开发者们的一大挑战。 DrawDB 应运而生,…

研发的立足之本到底是啥?

0 你的问题,我知道! 本文深入T型图“竖线”的立足之本:专业技术 + 技术赋能业务能力。研发在学习投入精力最多,也误区最多。 某粉丝感发展遇到瓶颈,项目都会做,但觉无提升,想跳槽。于是,梳理过往经历。 他觉得业务小,阻其技术发展。但细问,这系统用户量百万级,一点不…

Midscene.js:重新定义UI自动化的新时代工具

前言 Midscene.js 是一个创新的、面向开发者的 UI 自动化解决方案,并通过人工智能技术简化自动化脚本的编写与维护。 它提供了三种核心方法——交互(.ai, .aiAction)、提取(.aiQuery)和断言(.aiAssert),使开发者能够以自然语言描述步骤并执行复杂的UI操作。 它不仅支持…

Ant Design X:用最少的代码快速构建 AI 聊天界面

概述 随着人工智能(AI)技术的迅猛发展,尤其是通用人工智能(AGI)的进步,人机交互的方式正在经历深刻的变革。传统的图形用户界面(GUI)逐渐被更加自然、人性化的交互模式所取代。 为了应对这一变化,Ant Design X 团队提出了一种名为 RICH 的新设计范式,并开发了一系列专…