for (int i=1; i<=n; i++) { cin >> a[i]; } sort(a+1, a+n+1); for (int i=1; i<=n; i++) { //枚举B,使用二分查找满足a[j]==a[i]+c int q = a[i]+c; if (findleft(q)==0 && findright(q)==0) sum=0; else sum = findright(q) - findleft(q) + 1; a...
我们查找每个元素+C第一次出现的下标和最后一次出现的下标,再让最后一次出现的下标-第一次出现的下标+1(用sum不断累加这个值),最后sum的值就是A-B数对的个数。 3. 代码实现 #include<bits/stdc++.h> using namespace std; #define ll long longconstint N =2e5+10; int a[N], n, c; ll sum; i...
LL ans =0;for(inti=1;i<=n;i++){intk=a[i]+c;if(k>a[n])continue;//特判,如果+c后大于最后一个数,find函数会返回n,最后+1导致WAans +=Rfind(k)-Lfind(k)+1;//若k不存在但不比最后一个数大,则Lfind会返回插入这个数不影响有序性的后一个位置,Rfind会返回前一个,刚好差为-1} cout...
求a-b=c 的数对的个数,就是满足求出a=b+c的数对个数 先把数据从小到大排序, 枚举集合中的每一个元素b,二分找出第一个等于b+c的元素的位置pos1和第一个大于b+c元素的位置pos2 则[pos1, pos2-1]区间内的每一个元素都能与b构成一个数对 对于此时的b来说,能与其构成数对的方案数为pos2-pos1。
洛谷P1102 A-B数对 (双指针) 题目大意: 在An中,我们找出Ai - Aj == c的所有数对的个数。 n<=1e6 解题思路: 方法很多这里用一个巧妙的双指针完成,这种方法应该是代码量最短的。首先,我们可以对A从小到大进行排序。接着我们枚举指针j,找出Aj - Ai2>=c中的最靠右的位置,同时找出Aj - Ai1<=c中的...
P1102- A-B 数对(给一串数及一个数C,算 A-B=C 的数对的个数) 题目 输入样例#1: 4 1 1 1 2 3 输出样例#1: 3 说明 N≤2e5 所有输入数据都在longint范围内。 A-B=C,也就是对于每一个A找出来满足=A-C的B的个数。 1.排序完二分,对于每一个A,lower_bound,upper_bound (A-C) 的差就是...
【解题报告】洛谷P1102 A-B数对 【解题报告】洛谷P1102 A-B数对 题目链接 https://www.luogu.com.cn/problem/P1102 思路 我们可以统计数列中每个数字的数量,记录到 \(cnt[b[i]]\) 中,作为B 我们把 \(A-B=C\) 变换一下,就变成了 \(B+C=A\)...
简介:这是一个编程题目,要求计算给定正整数序列中满足A−B=C的数对个数。输入包含两行:正整数N和C,以及一串正整数。使用一个哈希映射记录每个数字出现的次数,然后遍历映射,如果找到A=B+C,则累加对应计数。样例输入输出为N=4,C=1,数列为1123,答案为3。代码使用 C++ 实现,通过维护一个映射来存储数字频率并计...
P1102 A-B 数对 题目背景 出题是一件痛苦的事情! 相同的题目看多了也会有审美疲劳,于是我舍弃了大家所熟悉的 A+B Problem,改用 A-B 了哈哈! 题目描述 给出一串正整数数列以及一个正整数 CC,要求计算出所有满足 A−B=CA−B=C 的数对的个数(不同位置的数字一样的数对算不同的数对)。 输入格式 输...
【洛谷】【二分查找】P1102 A−B数对 2018-06-21 16:54 −二分优化... DEVILK 0 608 B-树 2019-12-18 20:07 −## B-树 B-树的查找 B-树的插入 ```c++ //算法7.8 B-树的查找 //算法7.9 B-树的插入 #include using namespace std; #define FALSE 0 #define TRUE 1 #define OK 1...