Number of Pairs[二分查找函数]

2024-06-04 03:44

本文主要是介绍Number of Pairs[二分查找函数],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Number of Pairs

题面翻译

【题目描述】

给出一个由整数组成的数组 a a a,求一对整数 ( i , j ) (i, j) (i,j) 1 ≤ i < j ≤ n 1 \le i < j \le n 1i<jn)满足 l ≤ a i + a j ≤ r l \le a_i + a_j \le r lai+ajr 的数量。

【输入格式】

在输入的第一行为一个整数 t t t 1 ≤ t ≤ 10 4 1 \le t \le {10}^4 1t104),为数据组数。

接下来对于每组数据,第一行为三个整数 n , l , r n,l,r n,l,r 1 ≤ n ≤ 2 × 10 5 1 \le n \le 2 \times {10}^5 1n2×105 1 ≤ l ≤ r ≤ 10 9 1 \le l \le r \le {10}^9 1lr109),为数组的长度和上文中的 l , r l, r l,r。第二行有 n n n 个整数 a 1 , a 2 , … , a n a_1, a_2, \ldots , a_n a1,a2,,an 1 ≤ a i ≤ 10 9 1 \le a_i \le {10}^9 1ai109)表示数组 a a a

保证对于所有组数据 ∑ n ≤ 2 × 10 5 \sum n \le 2 \times {10}^5 n2×105

【输出格式】

对于每组数据,输出满足条件的 ( i , j ) (i,j) (i,j) 组数。

题目描述

You are given an array $ a $ of $ n $ integers. Find the number of pairs $ (i, j) $ ( $ 1 \le i < j \le n $ ) where the sum of $ a_i + a_j $ is greater than or equal to $ l $ and less than or equal to $ r $ (that is, $ l \le a_i + a_j \le r $ ).

For example, if $ n = 3 $ , $ a = [5, 1, 2] $ , $ l = 4 $ and $ r = 7 $ , then two pairs are suitable:

  • $ i=1 $ and $ j=2 $ ( $ 4 \le 5 + 1 \le 7 $ );
  • $ i=1 $ and $ j=3 $ ( $ 4 \le 5 + 2 \le 7 $ ).

输入格式

The first line contains an integer $ t $ ( $ 1 \le t \le 10^4 $ ). Then $ t $ test cases follow.

The first line of each test case contains three integers $ n, l, r $ ( $ 1 \le n \le 2 \cdot 10^5 $ , $ 1 \le l \le r \le 10^9 $ ) — the length of the array and the limits on the sum in the pair.

The second line contains $ n $ integers $ a_1, a_2, \ldots, a_n $ ( $ 1 \le a_i \le 10^9 $ ).

It is guaranteed that the sum of $ n $ overall test cases does not exceed $ 2 \cdot 10^5 $ .

输出格式

For each test case, output a single integer — the number of index pairs $ (i, j) $ ( $ i < j $ ), such that $ l \le a_i + a_j \le r $ .

样例 #1

样例输入 #1

4
3 4 7
5 1 2
5 5 8
5 1 2 4 3
4 100 1000
1 1 1 1
5 9 13
2 5 5 1 1

样例输出 #1

2
7
0
1

思路分析:
从前面往后面扫一遍,每次都已当前位置为左边界,然后二分查找允许的边界,边界之差就是以当前点为左边界的所有情况符合条件的合集

函数介绍:

lower_bound://找到大于等于某一个数x的第一个数
upper_bound://找到大于某一个数x的第一个数
lower_bound(w+1+i,w+2+n,a-w[i]) - w;
//起始位置,终点位置,大于等于的数x,-w是为了明确返回坐标
#include<iostream>
#include<algorithm>
#include<cstring>
#include<string>
using namespace std;
int t, l, r,n,a,b;
int w[200005];
int main()
{cin >> t;while (t--){int num = 0;cin >> n >> a >> b;for (int i = 1; i <= n; i++) cin >> w[i];sort(w + 1, w + 1 + n);//排个序w[n + 1] = 1e9;//最为结束的标志for (int i = 1; i <= n; i++){l = lower_bound(w+1+i,w+2+n,a-w[i]) - w;//从二号位开始找别忘了,我们是为了找最小右边界r = upper_bound(w+1+i,w+2+n,b-w[i]) - w;//从二号位开始找别忘了,我们是为了找最大右边界if (r > l) num += r - l;//答案数+++}cout << num << endl;}return 0;
}

这篇关于Number of Pairs[二分查找函数]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028973

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

python 常见数学公式函数使用详解(最新推荐)

《python常见数学公式函数使用详解(最新推荐)》文章介绍了Python的数学计算工具,涵盖内置函数、math/cmath标准库及numpy/scipy/sympy第三方库,支持从基础算术到复杂数... 目录python 数学公式与函数大全1. 基本数学运算1.1 算术运算1.2 分数与小数2. 数学函数

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(