ZR 2025 NOIP 二十连测 Day 5

news/2025/10/20 20:45:12/文章来源:https://www.cnblogs.com/littlebug520/p/19153611

呜呜我错了……我再也不开太大的 vector 了呜呜……/dk /dk /dk


25noip二十连测day5

链接:link
题解:题目内

时间:4h (2025.10.20 14:00~18:00)
题目数:4
难度:

A B C D
\(\color{#52C41A}绿\)
*1800

估分:[65,85] + 100 + 5 + 5 = [175,195]
得分:85 + 32 + 5 + 5 = 127
Rank:67/128


场祭

读题。

好困难!

想了 20min A 毫无头猪。

B 看起来是图论建模的样子,但是还是毫无头猪。

!然后看见了样例解释,注意到了差为 \(8\) 的倍数这一句话,于是想到同余!然后发现一条限制就可以表示成 \(w_{a_i} \equiv w_{b_i} + c_i \pmod {d_i}\),然后注意到 \(d_i = 2^k\),所以考虑给每个 \(2^k\) 开个 dsu,一条限制就转化成了图上的边。但是考虑到在模不同 \(2^k\) 意义下万一会有不同的唯一解,那就会产生错误了,所以要在 \(\le d_i\) 的每个 dsu 内都连上这条边,似乎是得到了一个必要条件,于是把必要当充分,写写写,过样例了!

(赛后看题解发现其实只用在 \(d_i\) 这一个 dsu 内连边就是对的,依然是必要当充分不考虑证明。

看了看 CD 暴力,发现都只会打最暴力的暴力,所以就从 A 开始打了。

然后发现 \(p_i \le 11\) 似乎可以爆搜,因为乘积的增长是非常迅速的。写写写,0ms 过掉了大样例,甚至还顺便过了 \(n \le 100\) 的大样例。

打 CD 暴力,发现暴力都不会了,分别拿了 5pts 提交答案和 5pts 特殊性质走人了。


补题

B 怎么 MLE 了/jk

原来是 vector 开的过多导致的,把 dsu 里面存连通块所有点的 vector 换成一个类似于前向星的存储方式就好了……

问了 gpt,原来一个空 vector 会存三个指针也就是 24 个字节,相当于 3 个 long long,可怕。

以后都这么写吧,能不开太多的 vector 就不开。

struct __dsu
{int n,d,mod,fa[N],sz[N],nxt[N],ed[N]; // nxt 下一条边,ed 连通块内最后一个点的编号il void init(int _n,int _d){n=_n,d=_d,mod=1<<_d; rep(i,0,n+1) fa[i]=i,nxt[i]=0,sz[i]=1,ed[i]=i;}il int find(int x) {return x==fa[x] ? fa[x] : fa[x]=find(fa[x]);}il bool merge(int a,int b,int c){int dlt=w[d][a]-c-w[d][b];a=find(a),b=find(b);if(a==b) return 0;sz[a]<sz[b] && (swap(a,b),dlt=-dlt);d<16 && (dlt=(dlt+mod*10)%mod,1);fa[b]=a,sz[a]+=sz[b],nxt[ed[a]]=b,ed[a]=ed[b];for(int u=b;u;u=nxt[u]) w[d][u]+=dlt,d<16 && (w[d][u]%=mod);return 1;}
} dsu[17];

天依宝宝可爱!

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

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

相关文章

关于单片机内部ADC采样率,采样精度的理解与计算整理 - 实践

关于单片机内部ADC采样率,采样精度的理解与计算整理 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Conso…

整体架构与数据流

下面给出对题目及当前代码求解方法的系统、深入解析,涵盖三问建模逻辑、数据流、关键算法、假设与局限、以及改进建议。内容按“题目需求 -> 代码实现 -> 差异/假设 -> 评估/改进”结构展开,方便你写论文或…

【上青了】

【上青了】赶紧把面板记录一下先,怕下次又又又掉了 没什么好讲的,本来上场打完就差 11 分,这场只要正常发挥就没问题变色,所以也没什么激动,该激动的上次都激动完了,哎哎哎 要说就是这次状态还行,不算差,前面 …

[VIM] reverse multiple lines in VIM

推荐方法: If you’re on a Unix-like system (FreeBSD, Linux, macOS), use :14,19!tac.来自chatgptTo reverse the display order of lines 51 to 54 in Vim, you can use the :g and :tac-style command combinati…

DeviceNet 转 Ethernet/IP:三菱 Q 系列 PLC 与欧姆龙 CJ2M PLC 在食品饮料袋装生产线包装材料余量预警的通讯配置案例

案例背景 DeviceNet 转 Ethernet/IP在食品饮料行业,包装生产线涉及多种设备,如灌装机、贴标机、封口机等。不同设备可能采用不同的工业总线协议,为了实现整个包装生产线的自动化控制和数据共享,需要将采用 Etherne…

【大模型】【扫盲】几种不同的微调方法

四种微调方式Full 对预训练模型的所有参数进行微调,让模型从底层到顶层的所有参数都参与更新,彻底适配下游任务 优点:模型对任务的适配性最强,在数据充足、任务复杂时效果通常最优 缺点:资源消耗极大(千亿参数模…

Tuack 生成比赛题目 PDF 笔记

Part 1. Tuack 的基本介绍 Tuack,是一个由来自 THU 的大佬 Mulab11 开发的,用于造算法竞赛题目的工具。 你可以用它:导出 PDF、Markdown、HTML 等多种不同格式,NOI、CPC 等不同风格的题面。 简单的出题人自评测功能…

在 wrapper 类里实现重载方法

现有包装类 Wrapper 欲覆盖 inner 的方法 g class A{void f(){g();}void g(){} }class Wrapper extends A{A inner;void f(){inner.f() // 不调用 Wrapper.g}void g(){ // override g} }inner 通过 this.g 调用时仍然会…

Vue 项目 AI 文档增量更新工具操作手册

一、工具目标 通过 AI 自动生成 Vue 组件 / JS 工具的工程化解释文档,并支持增量更新(仅处理新增 / 修改的文件),避免重复劳动,提升团队文档效率。 二、环境准备前置条件 已初始化的 Vue 项目(Vue 2 或 Vue 3 均…

P7521 [省选联考 2021 B 卷] 取模 分析

题目概述 给你 \(n\) 个数 \(a_i\)。 求:\(\max_{i\ne j\ne k}(a_i+a_j)\bmod a_k\)。 分析 好题! 我一开始看到是无从下手的。 但是细想一下,关键点在于 \(a_k\),所以的说,枚举 \(a_k\) 是必不可少的。 然后我们…

4060显卡也能玩转AI改图!Flux.1 Kontext Dev GGUF版本超详细入门教程 - 实践

4060显卡也能玩转AI改图!Flux.1 Kontext Dev GGUF版本超详细入门教程 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-fam…

提升生产力:8个.NET开源且功能强大的快速开发框架

提升生产力:8个.NET开源且功能强大的快速开发框架今天大姚给大家分享8个.NET开源、免费、功能强大的快速开发框架。助你提高开发生产效率、避免996!!! Vue.NetCore 一款基于Vue(提供Vue2/Vue3版本)和.Net Core前…

Mac版PDF Squeezer v4.5.1安装教程(DMG文件下载+详细步骤)​

Mac版PDF Squeezer v4.5.1安装教程(DMG文件下载+详细步骤)​​PDF Squeezer​ 是一款 ​Mac 专用​ 的 PDF 压缩工具,可以 ​快速减小 PDF 文件大小,同时尽量保持文件清晰度,适合 ​邮件发送、云端存储或节省空间…

使用c++14标准实现函数注册包装

调用方式bool res = FunctionRegistry::callFromFuncMap1<bool, type1&, type2*, type3,... >(...),其中第一个bool为返回值类型,第二个开始后面均为参数列表类型,可用于注册算子,包装函数指针等。 #inc…

【VSCode中Java创建环境安装的三个层级之Maven篇】(Windows版)

【VSCode中Java创建环境安装的三个层级之Maven篇】(Windows版)2025-10-20 20:15 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !imp…

黑马程序员Java基础笔记

目录类执行顺序继承方法重写构造器多态抽象类接口枚举类字符串内部类匿名内部类拆箱与装箱克隆浅克隆:深克隆:正则表达式Lambda方法引用静态方法引用实例方法引用特定类型方法引用构造器引用泛型通配符集合Collectio…

实用指南:linux磁盘空间爆满排查与清理

实用指南:linux磁盘空间爆满排查与清理pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Mo…

实用指南:socketpair深度解析:Linux中的“对讲机“创建器

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

详细介绍:从零开始的C++学习生活 2:类和对象(上)

详细介绍:从零开始的C++学习生活 2:类和对象(上)pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas",…