力扣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;
      }
  };
相关推荐
代码游侠1 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_763472461 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy2 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异2 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展
m0_706653232 小时前
分布式系统安全通信
开发语言·c++·算法
天天爱吃肉82183 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
alphaTao3 小时前
LeetCode 每日一题 2026/2/2-2026/2/8
算法·leetcode
甄心爱学习3 小时前
【leetcode】判断平衡二叉树
python·算法·leetcode
颜酱3 小时前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
不知名XL4 小时前
day50 单调栈
数据结构·算法·leetcode