差分转换+堆维护中位数,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

相关文章

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

使用PyTorch实现手写数字识别功能

《使用PyTorch实现手写数字识别功能》在人工智能的世界里,计算机视觉是最具魅力的领域之一,通过PyTorch这一强大的深度学习框架,我们将在经典的MNIST数据集上,见证一个神经网络从零开始学会识... 目录当计算机学会“看”数字搭建开发环境MNIST数据集解析1. 认识手写数字数据库2. 数据预处理的

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

Java实现XML与JSON的互相转换详解

《Java实现XML与JSON的互相转换详解》这篇文章主要为大家详细介绍了如何使用Java实现XML与JSON的互相转换,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. XML转jsON1.1 代码目的1.2 代码实现2. JSON转XML3. JSON转XML并输出成指定的

Java实现将Markdown转换为纯文本

《Java实现将Markdown转换为纯文本》这篇文章主要为大家详细介绍了两种在Java中实现Markdown转纯文本的主流方法,文中的示例代码讲解详细,大家可以根据需求选择适合的方案... 目录方法一:使用正则表达式(轻量级方案)方法二:使用 Flexmark-Java 库(专业方案)1. 添加依赖(Ma

Java实现将byte[]转换为File对象

《Java实现将byte[]转换为File对象》这篇文章将通过一个简单的例子为大家演示Java如何实现byte[]转换为File对象,并将其上传到外部服务器,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言1. 问题背景2. 环境准备3. 实现步骤3.1 从 URL 获取图片字节数据3.2 将字节数组