题解:CF895B XK Segments

我的 CSDN 原文地址,转载请标明

这道题好水,就是不好理解而已......

思路

暴力的复杂度是 n 2 n^2 n2 显然不可能通过

不难想到先排序,然后再使用二分查找。

lower_bound(begin, end, num) 可以返回一个有序序列 的不小于 n u m num num 的值的地址,不存在则返回 e n d end end。常用用法:通过返回的地址减去起始地址 b e g i n begin begin,得到找到数字在数组中的下标。

代码

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
using namespace std;
int n, x, k, a[100010], cnt;
int main() {
	ios :: sync_with_stdio(false);
	cin >> n >> x >> k;
	for (int i = 1; i <= n; i ++) cin >> a[i];
	sort(a + 1, a + n + 1);
	for (int i = 1; i <= n; i ++) {
		int l = (a[i] - 1) / x, r = l + k;
		cnt += lower_bound(a + 1, a + n + 1, (r + 1) * x) - lower_bound(a + 1, a + n + 1, max(r * x, a[i]));
	}
	cout << cnt << endl; 
	return 0;
}
相关推荐
十五年专注C++开发6 分钟前
设计模式之单例模式(二): 心得体会
开发语言·c++·单例模式·设计模式
?!71425 分钟前
算法打卡第18天
c++·算法
zh_xuan40 分钟前
c++ std::pair
开发语言·c++
CodeWithMe1 小时前
【C/C++】EBO空基类优化介绍
开发语言·c++
k要开心1 小时前
从C到C++语法过度1
开发语言·c++
whoarethenext2 小时前
使用 C/C++的OpenCV 实时播放火柴人爱心舞蹈动画
c语言·c++·opencv
能工智人小辰2 小时前
Codeforces Round 509 (Div. 2) C. Coffee Break
c语言·c++·算法
梦星辰.2 小时前
VSCode CUDA C++进行Linux远程开发
linux·c++·vscode
whoarethenext3 小时前
C++ OpenCV 学习路线图
c++·opencv·学习
闻缺陷则喜何志丹3 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点