洛谷$P1712\ [NOI2016]$区间 线段树
正解:线段树
解题报告:
$umm$很久以前做的了来补个题解$QwQ$
考虑给每个区间按权值($r-l$从大往小排序,依次加入,然后考虑如果有一个位置被覆盖次数等于$m$了就可以把权值最大的那个删去直到被覆盖次数小于$m$,顺便更新答案
然后就做完辣!$QwQ$
放下代码趴,然后因为是去年的代码了所以码风可能有点丑,,,懒得改了$QwQ$
$over$
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
int n,m,b[],c[],d[],mx[],add[],l=,r=,ans=0x7fffffff,num;
struct seg
{
int x,y,len;
inline bool operator <(const seg& rhs) const
{
return len>rhs.len;
}
}a[];
inline int read()
{
char ch=getchar();int x=;
while(ch>'' || ch<'')ch=getchar();
while(ch<='' && ch>='')x=(x<<)+(x<<)+(ch^''),ch=getchar();
return x;
}
inline void ins(int l,int r,int x,int y,int k,int v)
{
if (x<=l&&y>=r)
{
add[k]+=v;
mx[k]+=v;
return;
}
int mid=l+r>>;
if (x<=mid) ins(l,mid,x,y,k<<,v);
if (y>mid) ins(mid+,r,x,y,k<<|,v);
mx[k]=max(mx[k<<],mx[k<<|]);
mx[k]+=add[k];
}
int low(int x)
{
int l=,r=num,mid;
while (l<r)
{
mid=(l+r)>>;
if (b[mid]>=x) r=mid;
else l=mid+;
}
return l;
}
int main()
{
n=read(),m=read();
num=;
for (int i=;i<=n;i++)
{
a[i].x=read();
a[i].y=read();
a[i].len=a[i].y-a[i].x;
b[++num]=a[i].x;
b[++num]=a[i].y;
}
sort(a+,a+n+);
sort(b+,b+num+);
for (int i=;i<=n;i++) a[i].x=low(a[i].x),a[i].y=low(a[i].y);
for (int r=;r<=n;r++)
{
ins(,num,a[r].x,a[r].y,,);
while (mx[]>=m)
{
ans=min(ans,a[l].len-a[r].len);
ins(,num,a[l].x,a[l].y,,-);
l++;
}
}
if (ans!=0x7fffffff) printf("%d\n",ans);
else printf("-1");
return ;
}
洛谷$P1712\ [NOI2016]$区间 线段树的更多相关文章
- Luogu P1712 [NOI2016]区间(线段树)
P1712 [NOI2016]区间 题意 题目描述 在数轴上有 \(N\) 个闭区间 \([l_1,r_1],[l_2,r_2],...,[l_n,r_n]\) .现在要从中选出 \(M\) 个区间, ...
- 洛谷P1712 [NOI2016]区间 尺取法+线段树+离散化
洛谷P1712 [NOI2016]区间 noi2016第一题(大概是签到题吧,可我还是不会) 链接在这里 题面可以看链接: 先看题意 这么大的l,r,先来个离散化 很容易,我们可以想到一个结论 假设一 ...
- hdu 1540 Tunnel Warfare (区间线段树(模板))
http://acm.hdu.edu.cn/showproblem.php?pid=1540 Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others) ...
- BZOJ 3110 ZJOI 2013 K大数查询 树套树(权值线段树套区间线段树)
题目大意:有一些位置.这些位置上能够放若干个数字. 如今有两种操作. 1.在区间l到r上加入一个数字x 2.求出l到r上的第k大的数字是什么 思路:这样的题一看就是树套树,关键是怎么套,怎么写.(话说 ...
- 【bzoj3110】[Zjoi2013]K大数查询 权值线段树套区间线段树
题目描述 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c.如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数 ...
- 洛谷 P1712 [NOI2016]区间(线段树)
传送门 考虑将所有的区间按长度排序 考虑怎么判断点被多少区间覆盖,这个可以离散化之后用一棵权值线段树来搞 然后维护两个指针$l,r$,当被覆盖次数最多的点的覆盖次数小于$m$时不断右移$r$,在覆盖次 ...
- 洛谷P3372/poj3468(线段树lazy_tag)(询问区间和,支持区间修改)
洛谷P3372 //线段树 询问区间和,支持区间修改 #include <cstdio> using namespace std; struct treetype { int l,r; l ...
- 【BZOJ】1012: [JSOI2008]最大数maxnumber /【洛谷】1198(线段树)
Description 现在请求你维护一个数列,要求提供以下两种操作:1. 查询操作.语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度.2. 插 ...
- 洛谷题解P4314CPU监控--线段树
题目链接 https://www.luogu.org/problemnew/show/P4314 https://www.lydsy.com/JudgeOnline/problem.php?id=30 ...
随机推荐
- 20-1 django上传文件和项目里上传头像如何查看
一 普通上传方式 1 views def upload(request): if request.method == "POST": # print(request.POST) # ...
- oracle函数 LENGTH(c1)
[功能]返回字符串的长度; [说明]多字节符(汉字.全角符等),按1个字符计算 [参数]C1 字符串 [返回]数值型 [示例] SQL> select length('高乾竞'),length( ...
- L05 Laravel 教程 - 电商实战
https://laravel-china.org/courses/laravel-shop https://laravel-china.org/topics/13206/laravel-shop-c ...
- H3C 错误提示信息
- 你看Http的 三次握手
你看Http的 三次握手 按层次分,TCP位于传输层,而且TCP协议能够确认数据是否送达到对方,所以在客户端请求资源的时候,你得让俺知道咱俩关系是不是已经确定了啊,对不.这跟谈恋爱一样一样的,得先确定 ...
- poj 3601Tower of Hanoi
Tower of Hanoi Time Limit: 1000MS Memory Limit: 131072K Total Submissions: 1895 Accepted: 646 De ...
- 2001年NOIP普及组复赛题解
题目涉及算法: 数的计算:动态规划: 最大公约数和最小公倍数问题:质因数分解: 求先序排列:递归: 装箱问题:动态规划(纯0-1背包问题) 数的计算 题目链接:https://www.luogu.or ...
- 2018-8-10-win10-uwp-自定义控件初始化
title author date CreateTime categories win10 uwp 自定义控件初始化 lindexi 2018-08-10 19:16:50 +0800 2018-2- ...
- codeforces 609C
#include<bits/stdc++.h> using namespace std; ],c[]; int main() { int n,i; while(cin >> n ...
- sublime text3神器插件
(首先安装)Package Control Package Control,就像 Linux 下的 apt-get 和 yum 一样,它是 Sublime Text 的包管理器 1.Emmet 是一 ...