当前位置: 首页 > news >正文

qoj1831 Bruteforce

SOLUTION FROM WUMIN4

题意

若长度为 \(n\) 的数组 \(a\) 排序后为 \(b\),定义 \(a\) 的权值为 \(\sum_{i=1}^n \lfloor\frac{b_i\cdot i^k}{w}\rfloor \bmod 998244353\)

\(q\) 次操作,每次操作修改一个 \(a_i\),随后输出 \(a\) 的权值。

\(n,a_i\le 10^5,1\le k,w\le 5\)

思路

将式子拆成 \(\frac{\sum_{i=1}^n (b_i\cdot i^k-(b_i\cdot i^k) \bmod w)}{w}\)

于是我们要维护 \(\sum_{i=1}^n b_i\cdot i^k\)\(\sum_{i=1}^n (b_i\cdot i^k) \bmod w\)

由于 \(a_i\le 10^5\),可以在权值线段树上维护。

  1. \(\sum_{i=1}^n b_i\cdot i^k\)

假设左节点为 \(b_1 1^k+b_2 2^k+\cdots+b_l l^k\),右节点为 \(b'_1 1^k+b'_2 2^k+\cdots+b'_r r^k\)

则合并后有 \(b_1 1^k+b_2 2^k+\cdots+b_l l^k+b'_1 (l+1)^k+b'_2 (l+2)^k+\cdots+b'_r (l+r)^k\)

问题在于如何计算

\[\sum_{i=1}^r b'_i (l+i)^k \]

二项式定理拆开得到

\[\sum_{i=1}^r \sum_{j=0}^{k} b'_ii^j\binom{k}{j}l^{k-j} \]

换个位置

\[\sum_{j=0}^{k} \sum_{i=1}^r b'_ii^j\binom{k}{j}l^{k-j} \]

于是维护该节点的 \(f_j=\sum_{i=1}^r b'_ii^j\)。由于 \(\binom{k}{j}l^{k-j}\)\(i\) 无关,则有

\[\sum_{j=0}^{k} \binom{k}{j}l^{k-j} f_j \]

因为 \(k\le 5\),直接转移。

  1. \(\sum_{i=1}^n (b_i\cdot i^k) \bmod w\)
http://www.wxhsa.cn/company.asp?id=5027

相关文章:

  • C++数据结构和算法:链表
  • CAI:开源网络安全AI框架,打造自主安全测试智能体
  • GAS中,负责封装技能所影响的目标数据(如 Actor、位置、碰撞结果等)-FGameplayAbilityTargetData
  • 详细介绍:Maven入门_简介、安装与配置
  • 实用指南:立体校正原理
  • train-labels.idx1-ubyte里是什么
  • 滑动窗口最大值-leetcode
  • 创建预测窗口-ScopedPredictionWindow();
  • 95. 不同的二叉搜索树 II
  • lc1028-从先序遍历还原二叉树
  • P12558 [UOI 2024] Heroes and Monsters 题解
  • 加把劲——2025 年中总结
  • Ability-GetCurrentActorInfo()-IsLocallyControlled()和APawn::IsLocallyControlled()
  • 应该遵守的代码规范与读《数学之美》有感
  • AbilitySystemComponent和AbilityTask
  • AT_arc171_c [ARC171C] Swap on Tree
  • 202509_QQ_冷门的Base家族
  • SpawnActorDeferred()和SpawnActorOfClass()
  • 【QT】信号和槽
  • 学习日报|线程池专题学习总结 - 详解
  • 如何设计业务架构 - 智慧园区
  • snmp协议
  • 刷题复习(四)二分搜索
  • aardio | 通过点击checkbox复选框本身判断是否勾选
  • 项目介绍
  • 新媒体运营用AI排版工具|10分钟搞定公众号图文的全流程指南
  • 练习第一天学习的内容
  • 常见小错误 FREQUENTLY MADE MISTAKES IN OI
  • ctf工具整理
  • 力扣39题 组合总和