热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

摊还算法——贡献转移

贡献转移在计算每个元素的作用的时候,我们可以通过反向枚举作用效果,添加到作用元素的身上,这种方法叫做贡献转移。更正式的说,
贡献转移

在计算每个元素的作用的时候,我们可以通过反向枚举作用效果,添加到作用元素的身上,这种方法叫做贡献转移。更正式的说,设aia_iai为每个元素的作用数,集合BBB为作用效果,那么:

ai=∑b∈B,b→ai1a_i = \sum_{b \in B,b \to a_i} 1 ai=bB,bai1

例题

LeetCode 5874

考虑每一个位置的 pivot ,如果iii位置能够成为 pivot 的话,那么前后肯定存在一个位置jjj,将位置jjj变成kkk之后,该位置的 pivot 成立,那么我们称jjj位置对iii位置有一个贡献,此时我们可以用哈希表去记录jjj位置的数字,然后在遍历中进行贡献转移即可。

class Solution
{
public:int waysToPartition(vector<int> &nums, int k){long long lsum &#61; 0;long long rsum &#61; accumulate(nums.begin(), nums.end(), 0ll);unordered_map<long long, int> mp;vector<int> contrib(nums.size());int undo &#61; 0;for (int i &#61; 0; i < nums.size(); i&#43;&#43;){contrib[i] &#43;&#61; mp[nums[i]];if (i !&#61; nums.size() - 1){lsum &#43;&#61; nums[i];rsum -&#61; nums[i];if (rsum &#61;&#61; lsum){undo&#43;&#43;;}mp[rsum - lsum &#43; k]&#43;&#43;;}}mp.clear();lsum &#61; accumulate(nums.begin(), nums.end(), 0ll);rsum &#61; 0;for (int i &#61; nums.size() - 1; i >&#61; 0; i--){contrib[i] &#43;&#61; mp[nums[i]];if (i !&#61; 0){lsum -&#61; nums[i];rsum &#43;&#61; nums[i];mp[lsum - rsum &#43; k]&#43;&#43;;}}for (int i &#61; 0; i < nums.size(); i&#43;&#43;){undo &#61; max(undo, contrib[i]);}return undo;}
};

CF 1603C

我们可以枚举以xxx结尾&#xff0c;前驱为ai&#43;1a_i &#43; 1ai&#43;1⌈aiai&#43;1⌉−1\lceil \frac{a_i}{a_i &#43; 1} \rceil - 1ai&#43;1ai1贡献。设dp[i][x]dp[i][x]dp[i][x]表示为子数组a[i:j]a[i:j]a[i:j]最终以xxx结尾的子数组的数量&#xff0c;那么前面有iii个开头的子数组会得到这个贡献。即为i∗dp[i][x]∗(⌈aix⌉−1)i * dp[i][x] * (\lceil \frac{a_i}{x} \rceil - 1)idp[i][x](xai1)


int arr[100005];
int dp[2][100005];
vector<int> hold[2];
void solve()
{int n;scanf("%d", &n);for (int i &#61; 1; i <&#61; n; i&#43;&#43;)scanf("%d", arr &#43; i);ll ans &#61; 0;hold[0].clear();hold[1].clear();for (int i &#61; n; i >&#61; 1; i--){dp[i & 1][arr[i]]&#43;&#43;;hold[i & 1].push_back(arr[i]);int las &#61; arr[i];for (int x : hold[(i &#43; 1) & 1]){int pos &#61; arr[i] / ((arr[i] &#43; x - 1) / x);ll cnt &#61; dp[(i &#43; 1) & 1][x];dp[i & 1][pos] &#43;&#61; cnt;if (pos !&#61; las){hold[i & 1].push_back(pos);las &#61; pos;}ans &#61; (ans &#43; (i * ((cnt * (((arr[i] &#43; x - 1) / x) - 1)) % MOD353)) % MOD353) % MOD353;}for (int k : hold[(i &#43; 1) & 1])dp[(i &#43; 1) & 1][k] &#61; 0;hold[(i &#43; 1) & 1].clear();}for (int k : hold[0])dp[0][k] &#61; 0;for (int k : hold[1])dp[1][k] &#61; 0;cout << ans << endl;
}


推荐阅读
  • 本题探讨了在大数据结构背景下,如何通过整体二分和CDQ分治等高级算法优化处理复杂的时间序列问题。题目设定包括节点数量、查询次数和权重限制,并详细分析了解决方案中的关键步骤。 ... [详细]
  • 2018-2019学年第六周《Java数据结构与算法》学习总结
    本文总结了2018-2019学年第六周在《Java数据结构与算法》课程中的学习内容,重点介绍了非线性数据结构——树的相关知识及其应用。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 本教程详细介绍了如何使用 TensorFlow 2.0 构建和训练多层感知机(MLP)网络,涵盖回归和分类任务。通过具体示例和代码实现,帮助初学者快速掌握 TensorFlow 的核心概念和操作。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • Coursera ML 机器学习
    2019独角兽企业重金招聘Python工程师标准线性回归算法计算过程CostFunction梯度下降算法多变量回归![选择特征](https:static.oschina.n ... [详细]
  • 本文介绍如何使用MFC和ADO技术调用SQL Server中的存储过程,以查询指定小区在特定时间段内的通话统计数据。通过用户界面选择小区ID、开始时间和结束时间,系统将计算并展示小时级的通话量、拥塞率及半速率通话比例。 ... [详细]
  • 本文探讨了如何通过预处理器开关选择不同的类实现,并解决在特定情况下遇到的链接器错误。 ... [详细]
  • 本文详细探讨了Android Activity中View的绘制流程和动画机制,包括Activity的生命周期、View的测量、布局和绘制过程以及动画对View的影响。通过实验验证,澄清了一些常见的误解,并提供了代码示例和执行结果。 ... [详细]
  • LeetCode 690:计算员工的重要性评分
    在解决LeetCode第690题时,我记录了详细的解题思路和方法。该问题要求根据员工的ID计算其重要性评分,包括直接和间接下属的重要性。本文将深入探讨如何使用哈希表(Map)来高效地实现这一目标。 ... [详细]
  • 1.执行sqlsever存储过程,消息:SQLServer阻止了对组件“AdHocDistributedQueries”的STATEMENT“OpenRowsetOpenDatas ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
author-avatar
lock2502898047_947
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有