力扣719.找出第K小的数对距离

力扣719.找出第K小的数对距离

  • 二分答案

朴素版

  • 双指针遍历数组 超过界限break

cpp 复制代码
  auto check = [&](int mid) -> bool
  {
  	int res=0;
  	for(int i=0;i<n-1;i++)
  		for(int j=i+1;j<n;j++)
  		{
  			if(nums[j] - nums[i] > mid) break;
  			else
  				if(++res >= k) return true;
  		}
  	return false;
  };

优化版

  • 双指针遍历 j找到位置以后直接+=j - i - 1个数对

cpp 复制代码
  class Solution {
  public:
      int smallestDistancePair(vector<int>& nums, int k) {
          ranges::sort(nums);
          int n = nums.size();
          auto check = [&](int mid) -> bool
          {
              int res=0;
              for(int i=0,j=0;i<n-1;i++)
              {
                  while(j<n && nums[j] - nums[i] <= mid) j++;
                  res += j - i - 1;
                  if(res >= k) return true;
              }
              return false;
          };
          int l = 0,r = nums[n-1] - nums[0];
          while(l<r)
          {
              int mid = l + r >> 1;
              if(check(mid)) r = mid;
              else l = mid + 1;
          }               
          return l;
      }
  };
相关推荐
小白程序员成长日记10 分钟前
2025.11.06 力扣每日一题
算法·leetcode
不穿格子的程序员20 分钟前
从零开始写算法-栈-最小值(记忆化pair)
数据结构·
暴风鱼划水21 分钟前
算法题(Python)数组篇 | 4.长度最小的子数组
python·算法·力扣
gugugu.22 分钟前
算法:二分算法类型题目总结---(含二分模版)
算法
大G的笔记本26 分钟前
算法篇常见面试题清单
java·算法·排序算法
小龙报32 分钟前
《算法通关指南数据结构和算法篇(4)--- 队列和queue》
c语言·开发语言·数据结构·c++·创业创新·学习方法·visual studio
7澄11 小时前
深入解析 LeetCode 数组经典问题:删除每行中的最大值与找出峰值
java·开发语言·算法·leetcode·intellij idea
AI科技星1 小时前
宇宙的几何诗篇:当空间本身成为运动的主角
数据结构·人工智能·经验分享·算法·计算机视觉
前端小L1 小时前
二分查找专题(二):lower_bound 的首秀——精解「搜索插入位置」
数据结构·算法
老黄编程2 小时前
三维空间圆柱方程
算法·几何