力扣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;
      }
  };
相关推荐
海琴烟Sunshine5 小时前
leetcode 383. 赎金信 python
python·算法·leetcode
cynicme11 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员11 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称11 小时前
【递归】二进制字符串中的第K位
c++·算法
mjhcsp12 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛12 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
xier_ran12 小时前
深度学习:RMSprop 优化算法详解
人工智能·深度学习·算法
地平线开发者12 小时前
不同传感器前中后融合方案简介
算法·自动驾驶
地平线开发者13 小时前
征程 6X 常见 kernel panic 问题
算法·自动驾驶
com_4sapi14 小时前
2025 权威认证头部矩阵系统全景对比发布 双榜单交叉验证
大数据·c语言·人工智能·算法·矩阵·机器人