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

LeetCode 2563.统计公平数对的数目

给你一个下标从 0 开始、长度为 n 的整数数组 nums ,和两个整数 lower 和 upper ,返回 公平数对的数目 。

如果 (i, j) 数对满足以下情况,则认为它是一个 公平数对 :

0 <= i < j < n,且
lower <= nums[i] + nums[j] <= upper

示例 1:

输入:nums = [0,1,7,4,4,5], lower = 3, upper = 6
输出:6
解释:共计 6 个公平数对:(0,3)、(0,4)、(0,5)、(1,3)、(1,4) 和 (1,5) 。
示例 2:

输入:nums = [1,7,9,2,5], lower = 11, upper = 11
输出:1
解释:只有单个公平数对:(2,3) 。

提示:

1 <= nums.length <= 105^55
nums.length == n
-109^99 <= nums[i] <= 109^99
-109^99 <= lower <= upper <= 109^99

先对nums排序,然后可以用相向双指针找出两数之和小于等于upper的数对数,然后再用相向双指针找出两数之和小于lower的数对数,两者相减即可:

class Solution {
public:long long countFairPairs(vector<int>& nums, int lower, int upper) {sort(nums.begin(), nums.end());return getNum(nums, upper) - getNum(nums, lower - 1);}long long getNum(vector<int>& nums, int target) {long long ret = 0;int left = 0;int right = nums.size() - 1;while (left < right) {if (nums[left] + nums[right] > target) {--right;// 如果两指针指向的数之和<=target// 则[left + 1, right]之间的每个数都可以和left组成和<=target的数对} else {ret += right - left;++left;}}return ret;}
};

如果nums的长度为n,则此算法时间复杂度为O(nlogn),瓶颈在排序处,双指针循环的时间复杂度为O(n);空间复杂度为O(logn),主要是排序的栈开销。

http://www.xdnf.cn/news/1176643.html

相关文章:

  • Effective Python 第16条:用get处理字典缺失键,避免in与KeyError的陷阱
  • 【低空经济之无人集群】
  • runc源码解读(一)——runc create
  • C++右值引用与移动语义详解
  • QML 模型
  • git更新内核补丁完整指南
  • Android LiveData 全面解析:原理、使用与最佳实践
  • 【智能协同云图库】智能协同云图库第六弹:空间模块开发
  • 飞腾D3000麒麟信安系统下配置intel I210 MAC
  • Spring AI - 函数调用演示:AI算术运算助手
  • 复盘—MySQL触发器实现监听数据表值的变化,对其他数据表做更新
  • act_hi_taskinst表历史任务记录不同步,无数据
  • 边缘智能体:轻量化部署与离线运行
  • 三维手眼标定
  • 深度分析Java内存结构
  • Hexo - 免费搭建个人博客01 - 安装软件工具
  • IAR Embedded Workbench for ARM 8.1 安装教程
  • Web开发基础与RESTful API设计实践指南
  • 面试实战,问题七,Object类中包含哪些常用方法及其作用,怎么回答
  • python---元组(Tuple)
  • 嵌入式开发学习———Linux环境下数据结构学习(二)
  • M3066ANL网络变压器,常用于NEC方案机顶盒等网络设备M3066AN实现网络信号的稳定传输与电气隔离保护
  • 暑期自学嵌入式——Day06(C语言阶段)
  • 音视频学习(四十三):H264无损压缩
  • opencv学习(图像处理)
  • RLVR的一种扩展方案--RLPR论文阅读
  • window下c++共享内存,进程互斥锁。
  • 算法牢笼与思想飞地:在人工智能时代守卫灵魂的疆域
  • 【基于OpenCV的图像处理】图像预处理之图像色彩空间转换以及图像灰度化处理
  • 编程日常开发工具整理