热门标签 | 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;
}


推荐阅读
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 机器学习中的相似度度量与模型优化
    本文探讨了机器学习中常见的相似度度量方法,包括余弦相似度、欧氏距离和马氏距离,并详细介绍了如何通过选择合适的模型复杂度和正则化来提高模型的泛化能力。此外,文章还涵盖了模型评估的各种方法和指标,以及不同分类器的工作原理和应用场景。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • 尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ... [详细]
  • MATLAB中的类别数组:存储和操作有限类别的数据
    类别数组(categorical array)是MATLAB中用于存储有限类别数据的一种特殊数组类型。它不仅提供对非数值数据的高效存储和操作,还保留了原有类别的名称,使数据处理更加直观便捷。此外,类别数组可以与表格(table)数据类型结合使用,以实现更复杂的数据分析。 ... [详细]
  • 探索1000以内的完美数:因数和等于自身
    本文探讨了如何在1000以内找到所有完美数,即一个数的因数(不包括自身)之和等于该数本身。例如,6是一个完美数,因为1 + 2 + 3 = 6。通过编程实现这一过程,可以更好地理解完美数的特性。 ... [详细]
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社区 版权所有