差分转换+堆维护中位数,LeetCode LCP 24. 数字游戏

2024-02-01 10:20

本文主要是介绍差分转换+堆维护中位数,LeetCode LCP 24. 数字游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、题目

1、题目描述

小扣在秋日市集入口处发现了一个数字游戏。主办方共有 N 个计数器,计数器编号为 0 ~ N-1。每个计数器上分别显示了一个数字,小扣按计数器编号升序将所显示的数字记于数组 nums。每个计数器上有两个按钮,分别可以实现将显示数字加一或减一。小扣每一次操作可以选择一个计数器,按下加一或减一按钮。

主办方请小扣回答出一个长度为 N 的数组,第 i 个元素(0 <= i < N)表示将 0~i 号计数器 初始 所示数字操作成满足所有条件 nums[a]+1 == nums[a+1],(0 <= a < i) 的最小操作数。回答正确方可进入秋日市集。

由于答案可能很大,请将每个最小操作数对 1,000,000,007 取余。

2、接口描述

class Solution {
public:vector<int> numsGame(vector<int>& nums) {}
};

3、原题链接

LCP 24. 数字游戏


二、解题报告

1、思路分析

正难则反

我们可以知道最后的状态是公差为1的递增序列,那么我们就是找到长度为i的等差数列的和与Σa[i]的差的最小值,那么我们知道等差数列每一项都等于a[0] + (i - 1)d,所以我们将前i个元素转化为公差为1的数列就等效为将a[i] - i这i个元素变相等。

而对于n个元素变相等的最小代价是转换为中位数,这是个常用的结论,可以自己试着证明一下。

我们令原数组每个元素减去i,然后维护一个最大堆一个最小堆

大根堆存右半值,小根堆存左半值,小根堆元素数目比大根堆多1或者相等。

当元素数目为奇数,那么大根堆的元素和减去小根堆元素和+小根堆堆顶即为答案

当元素数目为偶数,那么大根堆的元素和减去小根堆元素和即为答案

2、复杂度

时间复杂度:O(nlogn) 空间复杂度:O(n)

3、代码详解

class Solution {
public:
static constexpr int MOD = 1e9 + 7;vector<int> numsGame(vector<int>& nums) {priority_queue<int> pq1;priority_queue<int,vector<int>,greater<int>> pq2;int n = nums.size();if(n == 1) return {0};for(int i = 0; i < n; i++) nums[i] -= i;pq2.emplace(max(nums[0], nums[1])) , pq1.emplace(min(nums[0], nums[1]));long long s1 = pq1.top(), s2 = pq2.top();vector<int> ret{0, static_cast<int>(s2 - s1)};for(int i = 2; i < n; i++){if(nums[i] <= pq1.top())pq1.emplace(nums[i]), s1 += nums[i];else pq2.emplace(nums[i]), s2 += nums[i];if(pq1.size() == pq2.size() + 2) pq2.emplace(pq1.top()), s1 -= pq1.top(), s2 += pq1.top(), pq1.pop();else if(pq2.size() > pq1.size())pq1.emplace(pq2.top()), s2 -= pq2.top(), s1 += pq2.top(), pq2.pop();ret.emplace_back((i & 1 ? s2 - s1 : s2 - s1 + pq1.top()) % MOD);}return ret;}
};

这篇关于差分转换+堆维护中位数,LeetCode LCP 24. 数字游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/666965

相关文章

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

使用Python实现网页表格转换为markdown

《使用Python实现网页表格转换为markdown》在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,本文将使用Python编写一个网页表格转Markdown工具,需... 在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,以便在文档、邮件或

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr

Java如何将文件内容转换为MD5哈希值

《Java如何将文件内容转换为MD5哈希值》:本文主要介绍Java如何将文件内容转换为MD5哈希值的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java文件内容转换为MD5哈希值一个完整的Java示例代码代码解释注意事项总结Java文件内容转换为MD5

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j