CodeForces 612D

来源:互联网 发布:java集合类原理 编辑:程序博客网 时间:2024/06/02 02:08

奇妙的思维题。

题意:

给定n个区间,求被覆盖至少k次的区间(两端连续的区间可以合并)最少有多少个。

思路:

某个区间被覆盖至少k次,即这个区间的左端点包括左端点的前面应该至少包括给定的k个区间起点,且这些区间的终点至少有k个在这个区间右端点包括右端点的后面。

所以可以这么想:给定的区间的左端点会贡献1,右端点会贡献-1,然后根据这n个区间即2*n个数进行排序(如果数值相同,根据贡献从1到-1排)。然后扫一遍这2*n个数,当贡献达到k时,开始统计区间,统计到后面第一个贡献小于k的点。为什么统计到第一个贡献小于k的点,可以这么想,前面贡献达到k的区间段一直覆盖到这个第一个贡献小于k的点(这个点必是某个区间的右端点),虽然右端点贡献是-1,但其实是闭区间,所以统计区间的时候这个点也应该被包括。


#include <algorithm>#include <iostream>#include <string.h>#include <cstdio>#include <vector>using namespace std;const int maxn = 1e6+5;struct node{int j, k;bool operator<(const node a) const{if(j == a.j) return k > a.k;return j < a.j;}} jk[maxn*2];vector<pair<int, int> > vt;int main(){int n, k, l, r;scanf("%d %d", &n, &k);for(int i = 0; i < n; ++i){scanf("%d %d", &l, &r);jk[i*2].j = l;jk[i*2].k = 1;jk[i*2+1].j = r;jk[i*2+1].k = -1;}n *= 2;sort(jk, jk+n);for(int i = 1; i < n; ++i) jk[i].k += jk[i-1].k;for(int i = 0; i < n; ++i){if(jk[i].k >= k){l = jk[i].j;while(i < n && jk[i].k >= k) ++i;r = jk[i].j;vt.push_back(make_pair(l, r));}}cout << vt.size() << endl;for(int i = 0, up = vt.size(); i < up; ++i){cout << vt[i].first << " " << vt[i].second << endl;}return 0;}

继续加油~

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 如果没有地球人类会怎么办 小锅盖被屏蔽了怎么办 美的冰箱故障通讯不合格怎么办 美的冰箱通讯不合格怎么办 文明6金币降到0怎么办 紫癜肾炎长期尿潜血怎么办 肾移植后血压高怎么办 尿道长了个肿瘤怎么办 吃了有病的鹅怎么办 狗狗得了乳腺瘤怎么办 孕28周还是臀位怎么办 怀孕五个月胎位不正怎么办 33周了胎位不正怎么办 足月胎儿不足5斤怎么办 绒癌观察期怀孕怎么办 宝宝囱门闭合晚怎么办 慢性硬脑膜下血肿复发怎么办 佝偻病导致囟门晚闭怎么办 儿童液体补多了怎么办 脑脊液鼻漏3年了怎么办 结石掉到膀胱里怎么办 肾结石引起的腰疼怎么办 肾结石小但很疼怎么办 狗狗得了尿结石怎么办 生理期第四天必须游泳怎么办 碎石后吐的厉害怎么办 白细胞高红细胞高血尿怎么办? 早期肾癌术后复发该怎么办 肾结石因运动引起尿血怎么办 宝宝大便镜检阳性潜血怎么办 尿不尽刺痛带血怎么办 狗狗拉肚子拉血怎么办 肾血肿怎么办才吸收快 体检尿蛋白高3怎么办 肾炎会引起脸肿怎么办 12小孩尿蛋白3是怎么办 肝癌介入手术后肝功能不好怎么办 屁多且臭便秘怎么办 肝癌术1年后复发怎么办 怀孕便秘怎么办或大便太干拉不出 肠鸣便秘怎么办多尿