题解: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;
}
相关推荐
阿让啊37 分钟前
C语言strtol 函数使用方法
c语言·数据结构·c++·单片机·嵌入式硬件
liulilittle1 小时前
OPENPPP2 —— IP标准校验和算法深度剖析:从原理到SSE2优化实现
网络·c++·网络协议·tcp/ip·算法·ip·通信
田里的水稻4 小时前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
Jayden_Ruan5 小时前
C++逆向输出一个字符串(三)
开发语言·c++·算法
liulun5 小时前
Skia如何渲染 Lottie 动画
c++·动画
点云SLAM6 小时前
C++ 常见面试题汇总
java·开发语言·c++·算法·面试·内存管理
UnnamedOrange8 小时前
ROS2 配置 linter 的代码格式化工具为 clang-format
c++·cmake
Dobby_058 小时前
【面试题】C++系列(一)
c++·面经
一拳一个呆瓜8 小时前
【MFC】对话框节点属性:Language(语言)
c++·mfc
点云侠10 小时前
解决Visual Studio 2022编译工程速度慢的问题
开发语言·c++·ide·算法·计算机视觉·visual studio