[AcWing] 2041. 干草堆(C++实现)差分+快排(第k个数)
1. 题目
2. 读题(需要重点注意的东西)
思路:
差分+快排
3. 解法
---------------------------------------------------解法---------------------------------------------------
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 1000010;
int n, m;
int b[N];
int quick_sort(int q[],int l,int r,int k){
if(l == r) return q[l];
int i = l -1,j = r + 1,x = q[l+r>>1];
while(i < j){
do i++;while(q[i]<x);
do j--;while(q[j]>x);
if(i < j) swap(q[i],q[j]);
}
if(j-l+1 >= k) return quick_sort(q,l,j,k);
else return quick_sort(q,j+1,r,k-(j-l+1));
}
int main()
{
scanf("%d%d", &n, &m);
while (m -- )
{
int l, r;
scanf("%d%d", &l, &r);
b[l] ++, b[r + 1] -- ;
}
for (int i = 1; i <= n; i ++ ) b[i] += b[i - 1]; // 构建差分数组
cout << quick_sort(b,1,n,n/2+1) << endl;
return 0;
}
可能存在的问题
4. 可能有帮助的前置习题
5. 所用到的数据结构与算法思想
- 差分
- 快速排序
6. 总结
差分的特征
就是在数组中的某一个区间内加上同一个数!