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

相关文章

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数

python中的高阶函数示例详解

《python中的高阶函数示例详解》在Python中,高阶函数是指接受函数作为参数或返回函数作为结果的函数,下面:本文主要介绍python中高阶函数的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录1.定义2.map函数3.filter函数4.reduce函数5.sorted函数6.自定义高阶函数

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Python Excel 通用筛选函数的实现

《PythonExcel通用筛选函数的实现》本文主要介绍了PythonExcel通用筛选函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录案例目的示例数据假定数据来源是字典优化:通用CSV数据处理函数使用说明使用示例注意事项案例目的第一

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C