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

每日算法:洛谷U535992 J-C 小梦的宝石收集(双指针、二分)

题目描述

小梦有 n 颗能量宝石,其中第 i 颗的能量为 ai​,但这些能量宝石十分不稳定,随时有可能发生崩坏,导致他们全部消失!

小梦想要留住宝石们,不希望他们发生崩坏,同时他发现:如果这些宝石的能量的极差越大,则这些宝石们越不稳定,因此他希望最小化这些宝石的能量的极差(最大值减去最小值的差值)。

小梦有一招点石成金的技能,这个技能可以以如下方式改变一些宝石的能量:

∙ 要么小梦选择一块能量最小的宝石,将他变成一块当前能量最大的宝石。

∙ 要么小梦选择一块能量最大的宝石,将他变成一块当前能量最小的宝石。

形式化的即:

∙ 选择 i (1≤i≤n,ai​=min(a1​,a2​,...,an​)),执行:ai​:=max(a1​,a2​,...,an​)。

∙ 或选择 i (1≤i≤n,ai​=max(a1​,a2​,...,an​)),执行:ai​:=min(a1​,a2​,...,an​)。

小梦至多可以使用 k 次上述的 ”点石成金“ 技能,他想知道这些宝石的能量极差最小可以变为多少,请你帮他算一算吧。

输入格式

本题有多组测试数据。

输入的第一行包含一个正整数 T,表示数据组数。

接下来包含 T 组数据,每组数据的格式如下:

第一行两个正整数 n,k,分别表示小梦拥有的宝石数量 n ,和他最多可以释放 “点石成金” 技能的次数 k。

第二行 n 个正整数 ai​,表示每块宝石的能量。

输出格式

对于每组测试数据:

在单独的一行输出一个整数,表示宝石能量的极差最小值。

输入输出样例

输入 #1

2
8 3
1 2 3 4 5 6 7 8
4 3
100 1 100 2

输出 #1

4
0

说明/提示

【样例 1 解释】

使用 3 次操作一,选择 min 变为 max,操作完后数组变成:{8,8,8,4,5,6,7,8}。

此时数组的极差为 4 最小,可以证明不存在比 4 更优的答案。

【数据范围】

令 N 表示 T 组数据中 n 的总和。

对于 30% 的数据有:T=1,1≤k≤N≤20。

对于 60% 的数据有:1≤T≤10,1≤k≤N≤2000。

对于所有的测试数据有: 1≤T≤1000,1≤N≤5×105,0≤k≤n,0≤ai​≤109。

思路:

我们很容易想到,先将数组进行排序,然后分别用两个指针l,和r表示最左侧的最大值和最右侧的最小值。

 每次只要有将最小值变成最大值或者将最大值变成最小值的情况出现,那么我们就需要移动左或右指针到次小或次大值的位置上。

这样,我们假设当l指针在i位置,r指针在j位置时,找到答案,则操作次数为:(i-1)【操作左边要用的次数】+(n-j)【操作右边要用的次数】+min(i-1,n-j)【将左边的值变成最大值或将右边的值变为最小值后,额外再需要移动的次数 例:如果左边是1,右边是8,修改左边后,最后面的两个数应该是8,8因此如果此时要再操作右边,应该额外加上左边的操作次数,同理另一种情况也是如此,而这个值我们希望它尽可能小,这样可操作的次数就会变多】

而由题目规定,我们可知:(i-1)+(n-j)+min(i-1,n-j) <= k

因此当符合这一规定时,我们 则用ans记录它的差值,取最小值。

于是我们可以很轻松的想到双重循环遍历枚举,但是双重循环肯定过不了,然后我们发现:该数组中的数是单调递增的,且满足二分性,因此我们可以将第二重循环优化为二分,这样的时间复杂度是nlogn。

代码:

#include<bits/stdc++.h>using namespace std;
int t,n,k;
const int N = 5e5+10;
int q[N];int main(){cin>>t;while(t--){cin>>n>>k;for(int i =1;i<=n;i++){cin>>q[i];}sort(q+1,q+n+1);//先从小到大排序 int ans = INT_MAX;//初始化为极大值 for(int i = 1;i<=n;i++){if(i - 1 > k) break;int l = i,r = n;//在从i到n的区间里找到右边界 if(i - 1>k) break;//操作次数超过k了,直接跳出 while(l <= r){int mid = (l+r) / 2;if((i-1) + (n - mid) + min(i-1,n-mid) <= k) r = mid-1;else l = mid+1;}ans = min(ans,q[l]-q[i]);//每次更新取最小值 }cout<<ans<<endl;}return 0;
}

相关文章:

每日算法:洛谷U535992 J-C 小梦的宝石收集(双指针、二分)

题目描述 小梦有 n 颗能量宝石&#xff0c;其中第 i 颗的能量为 ai​&#xff0c;但这些能量宝石十分不稳定&#xff0c;随时有可能发生崩坏&#xff0c;导致他们全部消失&#xff01; 小梦想要留住宝石们&#xff0c;不希望他们发生崩坏&#xff0c;同时他发现&#xff1a;如…...

写给新人的深度学习扫盲贴:ReLu和梯度

一、ReLU&#xff08;Rectified Linear Unit&#xff0c;修正线性单元&#xff09; 梯度是深度学习中最常用的激活函数之一&#xff0c;因其简单、高效且能有效缓解梯度消失问题而被广泛使用。 1. 数学定义 函数表达式&#xff1a; $$ \text{ReLU}(x) \max(0, x) \begin{…...

Spring 框架的核心基础:IoC 和 AOP

一、IoC&#xff08;Inversion of Control&#xff0c;控制反转&#xff09; 定义&#xff1a; IoC&#xff08;Inversion of Control&#xff0c;控制反转&#xff09;&#xff0c;就是把对象创建和依赖关系的管理交给 Spring 容器&#xff0c;而不是由程序员手动去创建对象…...

JavaScript逆向工程实战:如何精准定位加密参数生成位置

前言&#xff1a;一个令人困惑的调试案例 最近在进行某网站的JavaScript逆向分析时&#xff0c;我遇到了一个有趣的现象&#xff1a;当我尝试定位一个名为m的加密参数&#xff08;值为MTIwMTE3NDQxODk1NTY1NjkA这样的Base64字符串&#xff09;时&#xff0c;调试器却带我来到了…...

SSM智能停车场管理系统

&#x1f345;点赞收藏关注 → 添加文档最下方联系方式咨询本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345; 项目视频 SS…...

[定位器]晶艺LA1823,4.5V~100V, 3.5A,替换MP9487,MP9486A,启烨科技

Features  4.5V to 100V Wide Input Range  3.5A Typical Peak Current Limit  Integrated 500mΩ low resistance high side power MOS.  Constant On Time Control with Constant Switching Frequency.  180μA Low Quiescent Current  150kHz/240kHz/420kHz Swi…...

天元证券|A股大反攻!北证50涨超10%!芯片股大爆发

今日&#xff0c;A股全线走强。 科技成长股领涨&#xff0c;北证50指数飙升逾10%&#xff0c;科创50也大涨超4%&#xff0c;深证成指、上证指数午后也稳步拉升涨逾1%。值得注意的是&#xff0c;上证50指数临近收盘集合竞价的时候直线拉升。近4600只个股上涨&#xff0c;成交稳步…...

利用python从零实现Byte Pair Encoding(BPE):NLP 中的“变形金刚”

BPE&#xff1a;NLP 界的“变形金刚”&#xff0c;从零开始的奇幻之旅 在自然语言处理&#xff08;NLP&#xff09;的世界里&#xff0c;有一个古老而神秘的传说&#xff0c;讲述着一种强大的魔法——Byte Pair Encoding&#xff08;BPE&#xff09;。它能够将普通的文本“变形…...

最新Web系统全面测试指南

你有没有遇到过这样的情况&#xff1a; 系统上线当天&#xff0c;用户频频报错&#xff0c;运维一脸懵逼&#xff0c;开发说“我本地没问题”&#xff1f; 你明明写了几十个测试用例&#xff0c;结果却还是有 Bug 漏网&#xff1f; Web 系统测试&#xff0c;不只是点点点&#…...

OpenBMC:BmcWeb 处理http请求6 调用路由处理函数

OpenBMC:BmcWeb 处理http请求5 检查权限-CSDN博客 检查完权限后,调用了rule.handle(*req, asyncResp, params); template <typename... Args> class TaggedRule :public BaseRule,public RuleParameterTraits<TaggedRule<Args...>> {void handle(const Req…...

售货机管理系统:智慧零售时代的运营新引擎

一、引言 在快节奏的都市生活中,自动售货机已成为便捷消费的重要场景。然而,传统售货机依赖人工补货、手工对账,常面临库存失衡、设备故障发现滞后、数据孤岛等痛点。如何突破效率瓶颈?本文将深入剖析榕壹云售货机管理系统的项目背景、客户定位、技术与核心功能、系统优势…...

Python基础全解析:从输入输出到字符编码的深度探索

一、Python程序交互的基石&#xff1a;Print函数详解 1.1 基础输出功能 # 输出数字 print(20.5) # 输出浮点数&#xff1a;20.5 print(0b0010) # 输出二进制数&#xff1a;10# 输出字符串 print(Hello World!) # 经典输出示例# 表达式计算 print(4 4 * (2-1)…...

Python第八章02:数据可视化Pyecharts包无法使用

PS:本节纯属个人在学习过程中遇到问题、解决问题的经验分享&#xff0c;对学习进度没影响&#xff0c;没有遇到该问题的小伙伴可跳过。 首先&#xff0c;在学习数据图形化过程中&#xff0c;通过命令提示符安装了Pyecharts包&#xff0c;在命令提示符中验证安装成功。 在PyChar…...

【人工智能】如何通过精准提示工程实现完美的珠宝首饰展示

AI艺术创作指南&#xff1a;如何通过精准提示工程实现完美的珠宝首饰展示 引言&#xff1a;认知边界的突破 在AI艺术创作的漫长探索中&#xff0c;许多创作者面临着相似的困扰&#xff1a;当他们看到别人能够通过算法编织出如同文艺复兴时期细腻油画般的奢华珠宝展示图&#…...

Redis学习总结(持续更新)

Redis 目前在学习redis&#xff0c;遇到的一些问题会放在这里&#xff0c;加深自己的印象。 1. Redis缓存相较于传统Session存储的特点 Session的存储方式&#xff1a; 通常&#xff0c;传统的Session是存储在应用服务器的内存中&#xff0c;比如Tomcat的Session管理器。用户…...

RabbitMQ从入门到实战-3(高可靠性)

文章目录 发送者可靠性发送者重连发送者确认&#xff08;一般不会开启&#xff09;指定returncallback和confrimfallbacktips MQ可靠性数据持久化LazyQueue&#xff08;默认模式且不可更改&#xff09; 消费者的可靠性消费者确认机制消费者失败重试业务幂等性唯一消息id业务判断…...

RTK 实时动态定位概述

01 引言 RTK(实时动态定位,Real-Time Kinematic)是一种高精度的卫星导航定位技术,通过差分校正方法,将GNSS(全球导航卫星系统)的定位精度从米级提升至厘米级(通常1-3厘米),广泛应用于测绘、无人机、自动驾驶、精准农业等领域。 02 概述 1. RTK的基本原理 RTK的核…...

Conda 环境离线迁移实战:解决生产环境网络限制的高效方案20250409

Conda 环境离线迁移实战&#xff1a;解决生产环境网络限制的高效方案 在生产环境无法联网的前提下&#xff0c;如何高效、安全地部署 Python 虚拟环境&#xff0c;是许多企业在实际运维中必须面对的问题。特别是当前常见的开发环境基于 Miniconda&#xff0c;生产环境使用 Ana…...

dify使用知识库

注意 要用向量模型 导入文件 选择向量模型 要下载好后&#xff0c;才可以导入模型&#xff0c; 这个模型没法在ollama中run 聊天工具添加知识库 效果...

HTTP:一.概述

http是干嘛的? 超文本传输协议(英语:HyperText Transfer Protocol,缩写:HTTP)是一种用于分布式、协作式和超媒体信息系统的应用层协议。HTTP是万维网的数据通信的基础。设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法。通过HTTP或者HTTPS协议请求的资源由统…...

Appium工作原理及环境的搭建(1)

1、Appium的介绍&#xff1a; 一、什么是Appium Desktop&#xff1f; Appium Desktop是Appium项目的桌面版GUI工具&#xff0c;提供了一个友好的界面&#xff0c;用于启动Appium服务器、查看设备日志、与设备交互、调试自动化脚本等。相比于命令行工具&#xff0c;Appium Des…...

Interactron: Embodied Adaptive Object Detection(训练时进行更新参数) 还没看懂

Interactron: Embodied Adaptive Object Detection 创新点 这些方法通常存在两个主要的共同假设。第一&#xff0c;模型在固定的训练集上进行训练&#xff0c;并在预先录制的测试集上进行评估。第二&#xff0c;模型在训练阶段结束后保持冻结状态&#xff0c;即训练完成后不再…...

【Pandas】pandas DataFrame copy

Pandas2.2 DataFrame Conversion 方法描述DataFrame.astype(dtype[, copy, errors])用于将 DataFrame 中的数据转换为指定的数据类型DataFrame.convert_dtypes([infer_objects, …])用于将 DataFrame 中的数据类型转换为更合适的类型DataFrame.infer_objects([copy])用于尝试…...

Redis基础指令(Windows)

1.cmd命令行启动redis 直接cmd打开整个文件 1.1.启动server 输入指令&#xff1a; redis-server.exe redis.windows.conf 会进入serve端 1.2.启动客户端 &#xff01;&#xff01;重新打开一个cmd&#xff0c;方法和上面一样&#xff01;&#xff01; 之后输入 redis-…...

MV-DLS600P激光振镜立体相机(MV-DLS600P)重要参数解析

功能特性 采用激光振镜技术&#xff0c;亚毫米级图像采集精度 高能效激光模块配合精准曝光同步&#xff0c;性能更稳定 支持多帧融合&#xff0c;无惧金属工件表面反光干扰 支持RGB、深度图同步对齐输出&#xff0c;便于二次开发 配备窄带滤光片&#xff0c;抗干扰能力更强&…...

C语言【输出字符串中的大写字母】

题目 输出字符串中的大写字母 思路&#xff08;注意事项&#xff09; 纯代码 #include<stdio.h> #include<string.h>int main(){char str[20], ans[20];fgets(str, sizeof(str), stdin);str[strcspn(str, "\n")] \0;for (int i 0, j 0; i < strl…...

UniApp基于xe-upload实现文件上传组件

xe-upload地址&#xff1a;文件选择、文件上传组件&#xff08;图片&#xff0c;视频&#xff0c;文件等&#xff09; - DCloud 插件市场 致敬开发者&#xff01;&#xff01;&#xff01; 感觉好用的话&#xff0c;给xe-upload的作者一个好评 背景&#xff1a;开发中经常会有…...

deque容器

1.定义 也叫双端数组&#xff0c;可以对头部进行插入和删除。 2.与vector区别 3.内部工作原理 他是把整个地址划分成多块小地址&#xff08;缓冲区&#xff09;&#xff0c;然后有一个中控区去记录这些地址&#xff0c;然后访问的时候先通过中控区然后再转到相应的缓冲区&am…...

git 总结遇到的问题

git Push 报错 Push failed send-pack: unexpected disconnect while reading sideband packet Total 2269 (delta 418), reused 0 (delta 0), pack-reused 0 the remote end hung up unexpectedly 解决方案&#xff1a;增加 Git 的缓冲区&#xff0c;有时由于数据量大或网络…...

python基础语法11-文件读写

在 Python 中&#xff0c;文件操作是日常编程中的常见任务之一。Python 提供了简单且强大的工具来读取和写入文件。通过使用内置的 open() 函数、read()、readline()、write() 等方法&#xff0c;我们可以轻松实现对文件的操作。此外&#xff0c;Python 的 with 语句可以帮助我…...

Webstorm 使用搜不到node_modules下的JS内容 TS项目按Ctrl无法跳转到函数实现

将node_modules标记为不排除&#xff0c;此时要把内存改大&#xff0c;不然webstorm中途建立索引时&#xff0c;会因为内存不足&#xff0c;导致索引中途停止&#xff0c;造成后续搜索不出来 更改使用内存设置 内存调为4096 若出现搜不出来js内容时&#xff0c;请直接重启下该项…...

转行嵌入式,需要自学多久?

作为一个本硕都学机械&#xff0c;却阴差阳错进入嵌入式行业的老兵&#xff0c;这个问题我能聊一整天。十几年前我还在工厂车间穿着工装和机床打交道&#xff0c;偶然接触到单片机后就一发不可收拾。 转行这条路我走得异常艰辛&#xff0c;踩过的坑比写过的代码还多。去年我终…...

BLE 协议栈事件驱动机制详解

在 BlueNRG-LP 等 BLE 系统中,事件驱动是控制状态转移、数据交互和外设协作的基础。本文将深入讲解 BLE 协议栈中事件的来源、分发流程、处理结构与实际工程实践策略,帮助你构建稳定、可维护的 BLE 系统。 📦 一、BLE 事件的来源分类 BLE 协议栈中的事件严格来自协议栈本身…...

AI开发学习路线(闯关升级版)

以下是一份轻松版AI开发学习路线&#xff0c;用「闯关升级」的方式帮你从零开始变身AI开发者&#xff0c;每个阶段都配有有趣的任务和实用资源&#xff0c;保证不枯燥、可落地&#xff01;&#x1f447; 目录 &#x1f530; 新手村&#xff1a;打基础&#xff08;1-2个月&…...

突破,未观测地区罕见极端降雨的估计

文章中文总结&#xff08;重点为方法细节&#xff09; 一、研究背景与目的 在无测站或短观测记录地区&#xff0c;传统极值理论&#xff08;如GEV&#xff09;难以估计稀有极端降雨事件&#xff1b;本文提出一种新的区域化极值估计方法&#xff1a;区域化 Metastatistical Ex…...

zk源码—4.会话的实现原理一

大纲 1.创建会话 (1)客户端的会话状态 (2)服务端的会话创建 (3)会话ID的初始化实现 (4)设置的会话超时时间没生效的原因 2.分桶策略和会话管理 (1)分桶策略和过期队列 (2)会话激活 (3)会话超时检查 (4)会话清理 1.创建会话 (1)客户端的会话状态 (2)服务端的会话创建…...

快排算法 (分治实现)

本算法采用将整个数组划分成三个部分 <key key >key 在数组全是同一个数字时&#xff0c;也能达到NlogN的时间复杂度 下面的板书中i为遍历数组的下标 left为<key的最右边的下标 right为>key的最左边的下标 例题1&#xff1a;912. 排序数组 - 力扣&#xff0…...

P9242 [蓝桥杯 2023 省 B] 接龙数列

这道题说要求最少删多少个使剩下的序列是接龙序列&#xff0c;这个问题可以转换为序列中最长的接龙序列是多少&#xff0c;然后用总长度减去最长接龙序列的长度就可以了&#xff0c;在第一个暴力版本的代码中我用了两个for循环求出了所有的接龙序列的长度&#xff0c;但是会超时…...

未来 AI 发展趋势与挑战(AGI、数据安全、监管政策)

从 ChatGPT 的火爆到国内 DeepSeek、通义千问、百川智能等模型的兴起,AI 正以前所未有的速度走入各行各业。而下一阶段,AI 是否会发展出真正的“通用智能”(AGI)?数据隐私、技术伦理又该如何应对?本文将带你全面洞察未来 AI 的技术趋势与落地挑战。 一、AGI 的曙光:通用…...

驱动开发硬核特训 · Day 6 : 深入解析设备模型的数据流与匹配机制 —— 以 i.MX8M 与树莓派为例的实战对比

&#x1f50d; B站相应的视屏教程&#xff1a; &#x1f4cc; 内核&#xff1a;博文视频 - 从静态绑定驱动模型到现代设备模型 主题&#xff1a;深入解析设备模型的数据流与匹配机制 —— 以 i.MX8M 与树莓派为例的实战对比 在上一节中&#xff0c;我们从驱动框架的历史演进出…...

MyBatis 动态 SQL 使用详解

&#x1f31f; 一、什么是动态 SQL&#xff1f; 动态 SQL 是指根据传入参数&#xff0c;动态拼接生成 SQL 语句&#xff0c;不需要写多个 SQL 方法。MyBatis 提供了 <if>、<choose>、<foreach>、<where> 等标签来实现这类操作 ✅ 二、动态 SQL 的优点…...

数据结构实验4.1:链队列的基本操作

文章目录 一&#xff0c;问题描述二&#xff0c;基本要求三&#xff0c;算法分析链队列的存储结构设计基本操作的算法分析 四&#xff0c;示例代码五&#xff0c;实验操作六&#xff0c;运行效果 一&#xff0c;问题描述 编程实现有关链队列的下列基本操作。 &#xff08;1&am…...

独立部署及使用Ceph RBD块存储

Ceph RBD&#xff08;RADOS Block Device&#xff09; 是 Ceph 分布式存储系统中的块存储组件&#xff0c;类似于 AWS EBS、iSCSI 等。它独立于 OpenShift 或 IBM CP4BA&#xff0c;是一个分布式存储系统&#xff0c;提供高性能、可扩展性和容错能力&#xff0c;适用于数据库、…...

C++初阶-C++入门基础

目录 ​编辑 1.C的简介 1.1C的产生和发展 1.2C的参考文档 1.3C优势和难度 1.4C学习的建议 2.C的第一个程序 2.1打印Hello world 2.2头文件 2.3namespace命名空间 2.4&#xff1a;&#xff1a;作用域限定符 2.5namespace的延伸 2.6C的输入输出 3.总结 1.C的简介 …...

部署大模型不再难:DeepSeek + 腾讯云 HAI 实战教程

网罗开发 &#xff08;小红书、快手、视频号同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…...

算法训练之位运算

♥♥♥~~~~~~欢迎光临知星小度博客空间~~~~~~♥♥♥ ♥♥♥零星地变得优秀~也能拼凑出星河~♥♥♥ ♥♥♥我们一起努力成为更好的自己~♥♥♥ ♥♥♥如果这一篇博客对你有帮助~别忘了点赞分享哦~♥♥♥ ♥♥♥如果有什么问题可以评论区留言或者私信我哦~♥♥♥ ✨✨✨✨✨✨ 个…...

初识Linux:常见指令与权限的理解,以及相关衍生知识

目录 前言 关于linux的简介 代码开源 网络功能强大 系统工具链完整 一、Linux下的基本指令 1.ls指令 2.pwd指令 3.cd指令 4.whoami指令 5.touch指令 6.mkdir指令 7.rm指令 8.man指令 9.cp指令 10.mv指令 11.nano指令 12.cat指令 13.tac指令 14.more指令 15.less指令 16.head指令…...

PostgreSQL-数据库的索引 pg_operator_oid_index 损坏

报错信息&#xff1a; 连接测试失败 Error connecting to database: Connection failed: ERROR: index "pg_operator_oid_index" contains unexpected zero page at block 3 Hint: Please REINDEX it. 这个错误表明 PostgreSQL 数据库的索引 pg_operator_oid_index …...

数字图像处理作业4

数字图像处理 作业4 Project 4&#xff1a;Image Restoration The scoring method for this project is as follows&#xff1a; 1&#xff0e;Implement a blurring filter using the equation&#xff08;5&#xff0e;6&#xff0d;11&#xff0c;数字图像处理&#xff08;…...

Simulink中Signal Builder在新版中找不到怎么办

在较新的MATLAB版本中&#xff0c;新版Simulink中的Signal Builder用Signal Editor作为替代工具。 signal builder not shown in matlab - MATLAB Answers - MATLAB Central signalBuilderToSignalEditor 1.打开上面第二个链接 2.点击拷贝 3.然后在命令行中粘贴 4.然后就会…...