力扣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;
      }
  };
相关推荐
qq_41712925几秒前
C++中的桥接模式变体
开发语言·c++·算法
Hello World . .18 分钟前
数据结构:队列
c语言·开发语言·数据结构·vim
YuTaoShao37 分钟前
【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序
算法·leetcode·排序算法
吴维炜2 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
Σίσυφος19003 小时前
PCL Point-to-Point ICP详解
人工智能·算法
you-_ling3 小时前
数据结构:4.二叉树
数据结构
玄〤3 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法
weixin_395448914 小时前
main.c_cursor_0202
前端·网络·算法
senijusene4 小时前
数据结构与算法:队列与树形结构详细总结
开发语言·数据结构·算法
青桔柠薯片4 小时前
数据结构:队列,二叉树
数据结构