我们查找每个元素+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...
要求B=A−C 可以发现 B 一定在一个连续区间内 双指针维护这个连续区间 先对这个数列排序 使得每次移动 A 时, 区间必定单向移动, 避免了走回头路 算法复杂度: O(N) 代码# #include <bits/stdc++.h> const int MAXN = 2e5 + 5; #define calc(a, b) Num[b] - Num[a] #define int long long...
}longlongans=0;for(inti=1;i<=n;i++) { ans+=maps[a[i]+c]; }printf("%lld\n",ans);return0; } 2. 遍历数组,二分查找,总时间复杂度为O(nlogn) #include<bits/stdc++.h>usingnamespacestd;inta[200005]={0};intmain(){intn,c;scanf("%d%d",&n,&c);for(inti=1;i<=n;i++)scan...
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...
P1102 A-B 数对 1.题目 2.分析 3.代码 1.ans开int (❌) 2.ans开long long (√) 3.优化,利用upper_bound(),lower_bound() 4.总结 ...
洛谷P1102 A-B数对 (双指针) 题目大意: 在An中,我们找出Ai - Aj == c的所有数对的个数。 n<=1e6 解题思路: 方法很多这里用一个巧妙的双指针完成,这种方法应该是代码量最短的。首先,我们可以对A从小到大进行排序。接着我们枚举指针j,找出Aj - Ai2>=c中的最靠右的位置,同时找出Aj - Ai1<=c中的...
简介:这是一个编程题目,要求计算给定正整数序列中满足A−B=C的数对个数。输入包含两行:正整数N和C,以及一串正整数。使用一个哈希映射记录每个数字出现的次数,然后遍历映射,如果找到A=B+C,则累加对应计数。样例输入输出为N=4,C=1,数列为1123,答案为3。代码使用 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) 的差就是...
int u = upper_bound(a + 1, a + 1 + n, c + a[k]) - a; int l = lower_bound(a + 1, a + 1 + n, c + a[k]) - a; count += (u - l); } 最后注意这里的数组元素,和我们最后的组合数是没法想象是有多大的,所以需要开long long。
P1102 A-B 数对 题目背景 出题是一件痛苦的事情! 相同的题目看多了也会有审美疲劳,于是我舍弃了大家所熟悉的 A+B Problem,改用 A-B 了哈哈! 题目描述 给出一串正整数数列以及一个正整数 CC,要求计算出所有满足 A−B=CA−B=C 的数对的个数(不同位置的数字一样的数对算不同的数对)。 输入格式 输...