多校A层冲刺NOIP2024模拟赛18

T1 选彩笔(rgb)

签到题,但是没签上。。。

没想到三维前缀和,直接上了个bitset。

就是直接二分答案,然后枚举这三维每维的区间的起点,前缀和查数量是否 大于等于 $ K $ 即可,也可以把二分答案改为第一维的双指针,少一个 $ log $ 。

T2 兵蚁排序(sort)

比T1还签到,但是没写 freopen 挂 100。

从 $ b $ 数组里挨个去在 $ a $ 数组里匹配,然后 $ O(n) $ 拉过来就行。

T3 人口局 DBA(dba)

数学推式子。

但是有很多部分分的数位DP,骗了 97 分。

简单来说就是解一个方程满足 $ x_1 + x_2 + x_3 + ······ + x_{n-1} + x_{n} = sum , x1 \lt p , \forall \ \ i ∈ [1,n] \ \ 0 \le x_i \lt m $ 的解的个数。

首先不考虑 $ x1 \lt p $ 的限制,然后你就可以容斥,钦定有 $ k $ 个 $ x $ 是 大于 $ m $ 的,把他们斥掉,然后就有一个式子(直接插板):

\[f_{a,s} \sum_{k=0}^{a} (-1)^k \binom{a}{k} \binom{s-km+a-1}{a-1}
\]

如果考虑上 $ x1 \lt p $ 的限制,那就可以直接枚举 $ x1 $ ,所以有:

那个后面求和式的化简就是因为 组合数的下面那个不变,所以在杨辉三角上就是竖着的一列

如图:

T4 银行的源起(banking)

因为讲过了,所以这篇讲的简单点。 算了,还是稍微详细点吧。

首先考虑只有一个银行的时候怎么求,那肯定是所有人都往一个银行跑,所以枚举点然后算贡献?

其实这种题有 $ O (n) $ 做法。

首先以 1 为根,我们直接考虑每条边的贡献,对于一条边,他的权值是 $ w $ ,连接着点 $ j $ 和他的父亲 $ fa_j $ 。

对于这条边,要么是 $ j $ 和他的子树里面的点往上走经过这条边,要么是上面的点下来,这时候我们设 $ sz_j $ 是 $ j $ 及其子树里面的点的权值之和, $ tot $ 表示整棵树的权值和,直接取 $ w \times \min( sz_j , tot - sz_j) $ , 作为这条边的贡献即可。

为什么对,来证明一下:

上面的式子只能保证对于一条边来说是最优的,但是不能保证全局都是这样的,但其实全局最优可以被证明只有在每个都最优的时候才成立。

证毕。此时我们得到了 $ O(n) $ 解决一个银行的问题的方法。那如果有两个银行呢,这个时候也一定存在一条边没有人走,所以我们枚举一条边并把它断开,然后对于两棵树分别求贡献加和,即可 $ O(n^2) $ 解决。

$ O(n^2) $ 解决不了,那就看看能不能上数据结构优化。

优化肯定要从贡献方面入手,那就再看看那个贡献的式子, $ ans_j = w_j \times \min( sz_j , tot - sz_j ) $ ,这个 min 就很难直接优化,那就分讨, 如果 $ sz_j \le \frac{tot}{2} , ans_j = w_j \times sz_j $ ,否则 $ ans_j = w_j \times (tot - sz_j ) $ ,那么这东西可以上值域线段树,具体来说,对于 $ sz $ 开一颗值域线段树,然后维护好 $ \sum w_j 、 \sum w_j \times sz_j $ 然后就可以做了。

主体思路有了,具体的分析一下:

在这个图里面,我们将这棵树分成了两部分,一颗红的,一颗绿的,我们分别求贡献。

对于绿色的部分很好求,就用刚才的至于线段树就行,dfs时线段树合并 $ n( log (n) ) $ ,对于红色的部分稍微麻烦一点。

首先考虑红色的部分相对于原树有哪些变化:

红树的 $ tot = sz_1 - sz_j $

对于绿树中的根 $ j $ ,从他的父亲 $ x $ 到 1 的这条链上面的点 $ i $ , $ sz_i $ 都减少了 $ sz_j $ 。

首先链上的点的贡献肯定得单求,可以维护一颗树状数组,然后每次查询时先链减 ,然后问,但是一个技巧可以不用链减,现在的分讨条件是 $ sz_i - sz_j \le \frac{tot}{2} $ ,那么直接移项,分讨条件变为 $ sz_i \le \frac{tot}{2} + sz_j $ ,同时最后求的答案要用 减去 $ sz_j $ 之后的值。(写出式子来就会了)

接下来就是红树中除了链上的部分了,我们发现这部分很难直接求,线段树也不好维护,但是他就是全局除了链上和绿树上以外的所有点,所以我们求出全局对于 $ \frac{tot}{2} $ 的贡献,这部分可以弄一颗静态的全局线段树,也可以直接离散化后前缀和 ,然后减去 链上以及绿树中对于 $ \frac{tot}{2} $ 的贡献即可,这部分都可以用刚才维护的东西直接求。

那我们就求完了,这道题主要是多注意注意细节就行了。

多校A层冲刺NOIP2024模拟赛18的更多相关文章

  1. 多校B层冲刺NOIP20211111模拟12

    题面:PDFhttp://xn--gwt928b.accoders.com/pdf/10248/10248.pdfhttp://xn--gwt928b.accoders.com/pdf/10248/1 ...

  2. 【CJOJ P1957】【NOIP2010冲刺十模拟赛】数字积木

    [NOIP2010冲刺十模拟赛]数字积木 Description 小明有一款新式积木,每个积木上都有一个数,一天小明突发奇想,要是把所有的积木排成一排,所形成的数目最大是多少呢? 你的任务就是读入n个 ...

  3. 冲刺Noip2017模拟赛7 解题报告——五十岚芒果酱

    1.二叉树(binary) .二叉树 (binary.cpp/c/pas) [问题描述] 二叉排序树或者是一棵空树,或者是具有下列性质的二叉树: ()若左子树不空,则左子树上所有结点的值均小于它的根结 ...

  4. 冲刺Noip2017模拟赛8 解题报告——五十岚芒果酱

    1.鼎纹 [问题描述] 据说鼎纹的 种制造 式是 铜模印出来的,这是我国古代劳动 智慧 的结晶.铜模印过的地 ,会留下深深的印记,经过时间的炼化,洗 练成历史的遗存. 聪明的古代劳动人民拥有一个 a ...

  5. 冲刺Noip2017模拟赛4 解题报告——五十岚芒果酱

    题1 韬韬抢苹果(apple) [问题描述] 又到了收获的季节,树上结了许多韬韬,错了,是许多苹果,有很多个小韬韬都来摘苹 果.每个韬韬都想要最大的苹果,所以发生了争执,为了解决他们的矛盾,出题人定了 ...

  6. 冲刺Noip2017模拟赛2 解题报告——五十岚芒果酱

    题1 牛跑步(running) [题目描述] 新牛到部队,CG 要求它们每天早上搞晨跑,从 A 农场跑到 B 农场.从 A 农场到 B 农场中有 n- 个路口,分别标上号,A 农场为 号,B 农场为 ...

  7. 冲刺Noip2017模拟赛1 解题报告——五十岚芒果酱

    题1 国际象棋(chess) [问题描述] 有N个人要参加国际象棋比赛,该比赛要进行K场对弈.每个人最多参加2场对弈,最少参加0场对弈.每个人都有一个与其他人都不相同的等级(用一个正整数来表示).在对 ...

  8. 冲刺Noip2017模拟赛6 解题报告——五十岚芒果酱

    1.ksum(ksum) [问题描述] Peter喜欢玩数组.NOIP这天,他从Jason手里得到了大小为n的一个正整数 数组. Peter求出了这个数组的所有子段和,并将这n(n+)/2个数降序排序 ...

  9. 冲刺Noip2017模拟赛5 解题报告——五十岚芒果酱

    1. 公约数(gcd) [问题描述] 给定一个正整数,在[,n]的范围内,求出有多少个无序数对(a,b)满足 gcd(a,b)=a xor b. [输入格式] 输入共一行,一个正整数n. [输出格式] ...

  10. 冲刺Noip2017模拟赛3 解题报告——五十岚芒果酱

    题1  素数 [问题描述] 给定一个正整数N,询问1到N中有多少个素数. [输入格式]primenum.in 一个正整数N. [输出格式]primenum.out 一个数Ans,表示1到N中有多少个素 ...

随机推荐

  1. 聊一聊 Netty 数据搬运工 ByteBuf 体系的设计与实现

    本文基于 Netty 4.1.56.Final 版本进行讨论 时光芿苒,岁月如梭,好久没有给大家更新 Netty 相关的文章了,在断更 Netty 的这段日子里,笔者一直在持续更新 Linux 内存管 ...

  2. Webpack 核心流程

    我们是袋鼠云数栈 UED 团队,致力于打造优秀的一站式数据中台产品.我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值. 本文作者:霜序 三个阶段 初始化阶段 初始化参数:从配置文件.配置对 ...

  3. PLC 入口

    教程 全网最全西门子S7-1500PLC视频教程, https://www.bilibili.com/video/BV1Yi4y1U7Md?p=12&vd_source=7f5dfe09aaa ...

  4. Java 1.8 Stream流原理与用法总结

    一.接口设计 从Java1.8开始提出了Stream流的概念,侧重对于源数据计算能力的封装,并且支持序列与并行两种操作方式:依旧先看核心接口的设计: BaseStream:基础接口,声明了流管理的核心 ...

  5. Openstack-dashboard默认配额

    创建实例不超过10个 方法一 修改配置文件 在使用openstack的过程中,默认创建的实例最多10个,这是因为配额默认实例就是10 所以我们需要修改配置文件/etc/nova/nova.conf中的 ...

  6. Ubuntu18.04未发现WiFi适配器情况解决方案之一

    问题: 第一次你可能会遇见这种情况,ubuntu未发现Wifi适配器解决方案  无法打开WIfi 并告诉你没有WiFi适配器 解决方案: 解决方案如下: sudo modprobe -r ideapa ...

  7. 使用 `Roslyn` 分析器和修复器 对异步方法规范化返回Async结尾

    之前写过一篇使用修复器帮助添加头部注释文本的功能,今天使用Roslyn的代码修复器对异步返回方法规范化的功能 实现分析器 首先需要实现分析器,使用RegisterSyntaxNodeAction,分析 ...

  8. JavaScript – 小技巧 Tips

    1e6 等价于 1 + 后面 6 个零 console.log(1e6 === 1_000_000); 模拟 C# 的 Record Deconstruct class Size implements ...

  9. 处理英文中的单数复数 (pluralize, singular plural)

    因为英语很烂, 有时候很烦这个. 如果是 hard code 的情况, 如果我不清楚的话就会去这里找 https://www.wordhippo.com/what-is/the-plural-of/l ...

  10. LiveChat vs LiveAgent vs Front vs Email

    它们是什么? LiveChat, LiveAgent 算是同类产品. LiveChat 的核心(或者说起点)是 live chat 这个功能, 而 LiveAgent 的核心是 ticket. 如果拿 ...