题解: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;
}
相关推荐
No0d1es2 小时前
2025年第十六届蓝桥杯青少组省赛 C++编程 中级组真题
c++·青少年编程·蓝桥杯·省赛
千禧皓月2 小时前
【C++】基于C++的RPC分布式网络通信框架(二)
c++·分布式·rpc
AA陈超2 小时前
虚幻引擎5 GAS开发俯视角RPG游戏 P07-08 点击移动
c++·游戏·ue5·游戏引擎·虚幻
·白小白3 小时前
力扣(LeetCode) ——209. 长度最小的子数组(C++)
c++·算法·leetcode
ohnoooo93 小时前
251106 算法
数据结构·c++·算法
卡提西亚4 小时前
C++笔记-24-文件读写操作
开发语言·c++·笔记
m0_748248024 小时前
C++ 异常处理全解析:从语法到设计哲学
java·c++·word
m0_748248025 小时前
C++20 协程:在 AI 推理引擎中的深度应用
java·c++·人工智能·c++20
QT 小鲜肉6 小时前
【Git、GitHub、Gitee】按功能分类汇总Git常用命令详解(超详细)
c语言·网络·c++·git·qt·gitee·github
派大星爱吃猫6 小时前
C++中的inline函数(内联函数)
c++·inline·内联函数