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

C++二分算法: 找出第 K 小的数对距离

题目

数对 (a,b) 由整数 a 和 b 组成,其数对距离定义为 a 和 b 的绝对差值。
给你一个整数数组 nums 和一个整数 k ,数对由 nums[i] 和 nums[j] 组成且满足 0 <= i < j < nums.length 。返回 所有数对距离中 第 k 小的数对距离。
示例 1:
输入:nums = [1,3,1], k = 1
输出:0
解释:数对和对应的距离如下:
(1,3) -> 2
(1,1) -> 0
(3,1) -> 2
距离第 1 小的数对是 (1,1) ,距离为 0 。
示例 2:
输入:nums = [1,1,1], k = 2
输出:0
示例 3:
输入:nums = [1,6,1], k = 3
输出:5
参数范围
n == nums.length
2 <= n <= 104
0 <= nums[i] <= 106
1 <= k <= n * (n - 1) / 2

分析

排序不影响结果

数对的数量: n*(n-1)/2 ,任选两个数,共nn组数对,排除n个相等的索引,共n(n-1)。(a,b)和(b,a)只算一对。由于k取值范围[1,n*(n-1)/2],所以本题一定有解。
改成排序后,选取[i,j]和不排序的结果一样。 如果排序后,i和j的相对顺序不边,排序之前选取{i,j},排序选取的也是{i,j};如果排序后,相对顺序发生变化{i,j}变成{j,i}。数量不变。

二分

枚举差[0,1000*1000]。如果小于等于iSub的数对数量小于k,则一定不是答案。如果小于等于iSub的数对数量大于等于k,则取第一个(索引最小)。故用左开右闭空间。

GetLessEqual

nums[i] - x <=iSub
也就是 nums[i] - iSub<= x
也就是x >= nums[i] - iSub
枚举,并二分查找并计算nums[0,i)中大于等于 nums[i] - iSub的数量

代码

核心代码

class Solution {
public:
int smallestDistancePair(vector& nums, int k) {
sort(nums.begin(), nums.end());
int left = -1, right = 1000 * 1000;
while (right - left > 1)
{
const int mid = left + (right - left) / 2;
if (GetLessEqual(nums, mid) < k)
{
left = mid;
}
else
{
right = mid;
}
}
return right;
}
int GetLessEqual(const vector& nums, int iSub)
{
int iRet = 0;
for (int i = 1; i < nums.size(); i++)
{
const int iNum = nums.begin() + i - std::lower_bound(nums.begin(), nums.begin()+i, nums[i]-iSub );
iRet += iNum;
}
return iRet;
}
};

测试用例

template
void Assert(const T& t1, const T& t2)
{
assert(t1 == t2);
}

template
void Assert(const vector& v1, const vector& v2)
{
if (v1.size() != v2.size())
{
assert(false);
return;
}
for (int i = 0; i < v1.size(); i++)
{
Assert(v1[i], v2[i]);
}
}

int main()
{
vector nums;
int k = 0;
int res = 0;
{
Solution slu;
nums = { 1,3,1 };
int k = 1;
res = slu.smallestDistancePair(nums, k);
Assert(0, res);
}

//CConsole::Out(res);

}

扩展阅读

视频课程

有效学习:明确的目标 及时的反馈 拉伸区(难度合适),可以先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771

如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

相关下载

想高屋建瓴的学习算法,请下载《闻缺陷则喜算法册》doc版
https://download.csdn.net/download/he_zhidan/88348653

鄙人想对大家说的话
闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
墨家名称的来源:有所得以墨记之。
如果程序是一条龙,那算法就是他的是睛

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17

相关文章:

C++二分算法: 找出第 K 小的数对距离

题目 数对 (a,b) 由整数 a 和 b 组成&#xff0c;其数对距离定义为 a 和 b 的绝对差值。 给你一个整数数组 nums 和一个整数 k &#xff0c;数对由 nums[i] 和 nums[j] 组成且满足 0 < i < j < nums.length 。返回 所有数对距离中 第 k 小的数对距离。 示例 1&#x…...

【计算机网络笔记】网络层服务模型——虚电路网络

系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能&#xff08;1&#xff09;——速率、带宽、延迟 计算机网络性能&#xff08;2&#xff09;…...

软文推广过程中,如何精准定位受众

互联网发展带来信息的爆炸式增长&#xff0c;消费者的注意力成为稀缺资源&#xff0c;传统硬广很难获取用户注意&#xff0c;而软文凭借故事化、针对性的特点更能吸引用户注意&#xff0c;在软文推广中&#xff0c;我们只有精准定位受众才能更好地传播&#xff0c;今天媒介盒子…...

说说对React中类组件和函数组件的理解?有什么区别?

一、类组件 类组件&#xff0c;顾名思义&#xff0c;也就是通过使用ES6类的编写形式去编写组件&#xff0c;该类必须继承React.Component 如果想要访问父组件传递过来的参数&#xff0c;可通过this.props的方式去访问 在组件中必须实现render方法&#xff0c;在return中返回…...

Unity 实例化物体以及赋予到父物体之下

Unity 实例化物体并赋予父物体操作如下&#xff1a; public class ExampleScript : MonoBehaviour { public GameObject prefab; // 引用预制体 public Transform parentTran; // 引用父物体的 Transform void Update() { if (Input.GetKeyDown(KeyCode.Space)) { //…...

Docker 介绍

Docker 介绍 1 介绍1.1 概述1.2 资源高效利用1.3 发展历程1.4 组件1.5 工具1.6 对环境部署和虚拟化的影响1.7 优点1.8 容器技术核心CgroupNamespaceUnionFS 2 命令信息、状态、配置info命令用于显示当前系统信息、docker容器、镜像个数、设置等信息 镜像容器资源 3 安装3.1 版本…...

VScode连接Xshell 并解决【过程试图写入的管道不存在】报错

一.下载vscode 国内镜像&#xff1a; https://vscode.cdn.azure.cn/stable/6c3e3dba23e8fadc360aed75ce363ba185c49794/VSCodeUserSetup-x64-1.81.1.exe二.打开vscode在扩展搜索SSH并安装 三.添加主机 按F1选择添加新的ssh主机 按格式输入后在左边会出现电视的图标 之后输入…...

Redis之事务

文章目录 前言一、概述二、Redis事务使用1.正常执行事务2.取消事务3.编译型异常4.运行时异常&#xff08;1/0&#xff09;5.清空数据库6.监控1.乐观锁正常执行成功2.多线程 总结 前言 Redis事务本质&#xff1a;一组命令的集合&#xff01;一个事务中的所有命令都会被序列化&a…...

【数据结构】树与二叉树(五):二叉树的顺序存储(初始化,插入结点,获取父节点、左右子节点等)

文章目录 5.1 树的基本概念5.1.1 树的定义5.1.2 森林的定义5.1.3 树的术语5.1.4 树的表示 5.2 二叉树5.2.1 二叉树1. 定义2. 特点3. 性质引理5.1&#xff1a;二叉树中层数为i的结点至多有 2 i 2^i 2i个&#xff0c;其中 i ≥ 0 i \geq 0 i≥0。引理5.2&#xff1a;高度为k的二叉…...

【HarmonyOS】HarmonyOS备案获取公钥和指纹

【关键字】 HarmonyOS应用、鸿蒙应用、元服务、应用备案 HarmonyOS应用在华为云等平台进行应用备案时&#xff0c;平台需要提供用公钥和签名指纹的信息&#xff0c;Android可以直接通过keystore或jks签名文件进行签名信息获取&#xff0c;HarmonyOS签名方式与Android不同&…...

,多数据源+Mybatisplus + Sharding JDBC同一库中分表

水平分表是在同一个数据库内&#xff0c;把同一个表的数据按一定规则拆到多个表中,多数据源采用 mybatis-plus的dynamic-datasource 分库分表采用sharding-jdbc 数据库连接池管理是alibaba的druid-spring-boot-starter 同一个数据库内分表 目录 1.数据库表 2.配置 3.引入的…...

Docsify 和 Hugo 之间的选型

对文档的编译&#xff0c;目前的发布方案是越来越注重 MD 的编辑和发布。 针对其他 Wiki 的选择&#xff0c;MD 文件的编辑通常会保留修改记录&#xff0c;同时不依赖中央数据库和其他类型的 Web 应用服务。 随着各大云平台的支持&#xff0c;包括 GitHub Page 和 Google 的 …...

第二十章 ObjectScript 应用程序中的数值计算 - 转换:十进制到 $DOUBLE

文章目录 第二十章 ObjectScript 应用程序中的数值计算 - 转换&#xff1a;十进制到 $DOUBLE 转换&#xff1a;十进制到 $DOUBLE转换&#xff1a;$DOUBLE 到十进制$DECIMAL(x)$DECIMAL(x, n) 转换&#xff1a;十进制到字符串 第二十章 ObjectScript 应用程序中的数值计算 - 转…...

C语言【趣编程】我们怎样便捷输出空心的金字塔

目录 1问题&#xff1a; 2解题思路&#xff1a; 3代码如下&#xff1a; 4代码运行结果如下图所示&#xff1a; 5总结&#xff1a; r如若后续有不会的问题&#xff0c;可以和我私聊&#xff1b; 1问题&#xff1a; 2解题思路&#xff1a; 方法&#xff1a;找规律&#xff0…...

《JavaScript设计模式》笔记 - - - 超全设计模式概览

该篇文章用于记录阅读《JavaScript设计模式》后归纳的读书笔记&#xff0c;主要以代码形式进行展示&#xff0c;用于快速回顾对应设计模式的代码构造 1.面向对象编程 1.使用对象收编变量 优点&#xff1a;避免全局变量冲突与覆盖 缺点&#xff1a;不利于复用 var CheckObj {c…...

浅谈Vue 3的响应式对象: ref和reactive

Vue 3是一个流行的前端框架&#xff0c;它引入了一些新的特性来提高开发者的体验和性能。其中&#xff0c;响应式对象是 Vue 3 中一个非常重要的概念。在这篇博客中&#xff0c;我们将重点介绍 Vue 3 中的响应式对象&#xff0c;并深入探讨其中的 ref 和 reactive。 引言 在现…...

怎么学编程效率高,编程练习网站编程软件下载,中文编程开发语言工具下载

怎么学编程效率高&#xff0c;编程练习网站编程软件下载&#xff0c;中文编程开发语言工具下载 给大家分享一款中文编程工具&#xff0c;零基础轻松学编程&#xff0c;不需英语基础&#xff0c;编程工具可下载。 这款工具不但可以连接部分硬件&#xff0c;而且可以开发大型的…...

Alphago Zero的原理及实现:Mastering the game of Go without human knowledge

近年来强化学习算法广泛应用于游戏对抗上&#xff0c;通用的强化学习模型一般包含了Actor模型和Critic模型&#xff0c;其中Actor模型根据状态生成下一步动作&#xff0c;而Critic模型估计状态的价值&#xff0c;这两个模型通过相互迭代训练&#xff08;该过程称为Generalized …...

STM32 堆栈空间分布

参考 运行时访问__initial_sp和__heap_base 无RTOS时的情况 在以上配置的情况下&#xff0c;生成工程。在工程的startup.s文件中&#xff0c;由如下代码&#xff1a; Stack_Size EQU 0x400AREA STACK, NOINIT, READWRITE, ALIGN3 __Stack_top ; 自己添加 Stack_Mem…...

小程序制作(超详解!!!)第十五节 自动随机变化的三色旗

1.例题描述 设计一个小程序&#xff0c;开始时界面上显示一个三色旗和一个按钮&#xff0c;当点击按钮时&#xff0c;三色旗的颜色会发生随机变化&#xff0c;即使不点击按钮&#xff0c;三色旗的颜色也会每隔一定时间自动发生变化。 2.index.wxml <view class"box&…...

Win11Debloat:彻底释放Windows系统潜能的终极优化工具

Win11Debloat&#xff1a;彻底释放Windows系统潜能的终极优化工具 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter and cu…...

5个必知技巧:rgthree-comfy如何让你的ComfyUI工作流更智能高效?

5个必知技巧&#xff1a;rgthree-comfy如何让你的ComfyUI工作流更智能高效&#xff1f; 【免费下载链接】rgthree-comfy Making ComfyUI more comfortable! 项目地址: https://gitcode.com/gh_mirrors/rg/rgthree-comfy 你是否曾在使用ComfyUI时感到工作流程杂乱无章&am…...

锐捷交换机NFPP配置避坑指南:汇聚层端口限速调多少才不误伤用户?

锐捷交换机NFPP实战调优&#xff1a;如何平衡安全防护与业务连续性 当园区网的ARP请求如潮水般涌向汇聚层交换机时&#xff0c;NFPP功能就像一位严格的安检员——设置过于宽松会导致CPU资源被恶意流量耗尽&#xff0c;而阈值过于苛刻又会误伤正常业务流量。去年某高校网络中断事…...

DeepSeek V4利好国产算力,超节点成为弯道超车的技术底座

超节点架构以系统级工程补齐单点算力短板&#xff0c;满足了从万亿参数大模型训练到规模化AI推理的多样化需求。2026年4月24日&#xff0c;DeepSeek发布了新一代旗舰模型DeepSeek V4&#xff0c;将总参数推至1.6万亿&#xff0c;首次将百万Token上下文打成标配&#xff0c;并实…...

前端架构演进历程

前端架构演进历程&#xff1a;从简单到复杂的蜕变 前端技术的发展如同一部精彩的进化史&#xff0c;从最初的静态页面到如今的复杂应用&#xff0c;架构的每一次变革都推动了用户体验和开发效率的飞跃。随着互联网的普及和技术的迭代&#xff0c;前端架构经历了多次重大转型&a…...

MySQL性能优化:深入理解索引原理与查询优化实战

作为一名后端开发&#xff0c;MySQL是绕不开的必修课。在日常工作中&#xff0c;慢查询往往是系统性能的头号杀手&#xff0c;而索引则是解决这一问题的核心利器。本文将带你从索引的本质出发&#xff0c;深入B树原理&#xff0c;结合Explain工具分析慢SQL&#xff0c;并总结一…...

从RS-485接线到报文解析:手把手带你用Wireshark抓包分析PROFIBUS-DP网络(实战排错)

从RS-485接线到报文解析&#xff1a;手把手带你用Wireshark抓包分析PROFIBUS-DP网络&#xff08;实战排错&#xff09; 在工业自动化现场&#xff0c;PROFIBUS-DP网络的稳定性直接关系到生产线的运行效率。当出现通信中断、数据丢包或从站异常时&#xff0c;传统的"重启大…...

告别全表编辑!用ABAP ALV实现采购订单行项目的条件可编辑(附完整Demo)

ABAP ALV动态编辑采购订单行项目的实战技巧 在SAP系统开发中&#xff0c;采购订单审批流程经常需要根据业务规则对字段进行精细化控制。想象这样一个场景&#xff1a;采购部门希望审批时只能修改数量大于1的行项目&#xff0c;其他字段和行保持锁定状态。这种需求无法通过简单…...

告别Cesium地形加载慢!用Docker+CTB快速切片你的DEM数据(保姆级教程)

告别Cesium地形加载慢&#xff01;用DockerCTB快速切片你的DEM数据&#xff08;保姆级教程&#xff09; 当你在Cesium项目中加载高精度地形时&#xff0c;是否遇到过浏览器卡顿、数据加载缓慢的困扰&#xff1f;传统的手工处理流程不仅耗时费力&#xff0c;还难以保证输出质量的…...

【YOLOv11】063、YOLOv11与神经架构搜索:用NAS自动寻找最优结构

从一次失败的调参说起 上周在部署YOLOv11到边缘设备时遇到性能瓶颈:模型在Jetson Orin上跑不到实时帧率。手动调整了卷积核尺寸、通道数、注意力模块位置,折腾两天,精度掉了3个点,速度却只提升5%。这种“盲人摸象”式的结构优化让我开始重新审视:为什么不让算法自己寻找最…...