BZOJ 3022 [Balkan2012]The Best Teams(扫描线+线段树)
【题目链接】 http://www.lydsy.com/JudgeOnline/problem.php?id=3022
【题目大意】
给定n个球员,第i个球员年龄为AGEi,水平为SKILLi。
没有任何两个球员的水平相同。将这些球员按水平排序,
对于一次比赛,你需要选择若干个球员去比赛,但不能同时选择两个水平相邻的球员。
m次询问,每次给定a和k,表示要在年龄不超过a的球员中选择不超过k个球员,
请计算skill和的最大值。
【题解】
对于询问年龄的限制,我们可以通过扫描线来处理。
我们将所有人的水平映射到线段上,随着线扫描在相应的位置更新上水平,
那么问题就转化为在权值线段树上求解k个不相邻的位置,使得权值和最大,
我们维护g[0/1]数组表示r+1不选/选的时候,l位置选不选
c[0/1]数组表示r+1不选/选的时候,中间选了几个。
s[0/1]数组表示r+1不选/选的时候,中间选的和。
查询则类似权值线段树上的k大数查询。
学习了一下Claris的非递归线段树写法。
【代码】
#include <cstdio>
#include <algorithm>
using namespace std;
typedef long long LL;
const int N=300010,M=N<<2;
int n,m,disc[N];
LL ans[N];
struct E{int x,y,id;}a[N],b[N];
bool cmp(E a,E b){return a.x<b.x;}
namespace Segment_Tree{
int pos[N];
struct data{bool g[2];int c[2];LL s[2];}T[M];
void build(int x,int l,int r){
if(l==r){pos[l]=x;return;}
int mid=(l+r)>>1;
build(x<<1,l,mid);build(x<<1|1,mid+1,r);
}
void change(int x,int y){
x=pos[x];
T[x].g[0]=T[x].c[0]=1,T[x].s[0]=y;
for(x>>=1;x;x>>=1)for(int i=0;i<2;i++){
bool j=T[x<<1|1].g[i];
T[x].g[i]=T[x<<1].g[j];
T[x].c[i]=T[x<<1].c[j]+T[x<<1|1].c[i];
T[x].s[i]=T[x<<1].s[j]+T[x<<1|1].s[i];
}
}
LL ask(int k){
int x=1,l=1,r=n,u=0;
LL res=0;
while(k){
if(k>=T[x].c[u]){res+=T[x].s[u];break;}
if(l==r)break;
int mid=(l+r)>>1;
x=x<<1|1;
if(k<=T[x].c[u])l=mid+1;
else{
k-=T[x].c[u];
res+=T[x].s[u];
u=T[x].g[u];
r=mid;
x--;
}
}return res;
}
}
int remark(int x){
int l=1,r=n;
while(l<=r){
int mid=(l+r)>>1;
if(disc[mid]<x)l=mid+1;
else if(disc[mid]==x)return mid;
else r=mid-1;
}
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d%d",&a[i].x,&a[i].y),disc[i]=a[i].y;
scanf("%d",&m);
for(int i=1;i<=m;i++)scanf("%d%d",&b[i].x,&b[i].y),b[i].id=i;
sort(a+1,a+n+1,cmp); sort(b+1,b+m+1,cmp); sort(disc+1,disc+n+1);
Segment_Tree::build(1,1,n);
for(int i=1,j=1;i<=m;i++){
while(j<=n&&a[j].x<=b[i].x)Segment_Tree::change(remark(a[j].y),a[j].y),j++;
ans[b[i].id]=Segment_Tree::ask(b[i].y);
}for(int i=1;i<=m;i++)printf("%lld\n",ans[i]);
return 0;
}
BZOJ 3022 [Balkan2012]The Best Teams(扫描线+线段树)的更多相关文章
- HDU 3642 - Get The Treasury - [加强版扫描线+线段树]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3642 Time Limit: 10000/5000 MS (Java/Others) Memory L ...
- 【BZOJ3958】[WF2011]Mummy Madness 二分+扫描线+线段树
[BZOJ3958][WF2011]Mummy Madness Description 在2011年ACM-ICPC World Finals上的一次游览中,你碰到了一个埃及古墓. 不幸的是,你打开了 ...
- HDU 3265/POJ 3832 Posters(扫描线+线段树)(2009 Asia Ningbo Regional)
Description Ted has a new house with a huge window. In this big summer, Ted decides to decorate the ...
- 【bzoj4491】我也不知道题目名字是什么 离线扫描线+线段树
题目描述 给定一个序列A[i],每次询问l,r,求[l,r]内最长子串,使得该子串为不上升子串或不下降子串 输入 第一行n,表示A数组有多少元素接下来一行为n个整数A[i]接下来一个整数Q,表示询问数 ...
- hdu1542 Atlantis(扫描线+线段树+离散)矩形相交面积
题目链接:点击打开链接 题目描写叙述:给定一些矩形,求这些矩形的总面积.假设有重叠.仅仅算一次 解题思路:扫描线+线段树+离散(代码从上往下扫描) 代码: #include<cstdio> ...
- [BZOJ 3123] [SDOI 2013]森林(可持久化线段树+并查集+启发式合并)
[BZOJ 3123] [SDOI 2013]森林(可持久化线段树+启发式合并) 题面 给出一个n个节点m条边的森林,每个节点都有一个权值.有两种操作: Q x y k查询点x到点y路径上所有的权值中 ...
- P3722 [AH2017/HNOI2017]影魔(单调栈+扫描线+线段树)
题面传送门 首先我们把这两个贡献翻译成人话: 区间 \([l,r]\) 产生 \(p_1\) 的贡献当且仅当 \(a_l,a_r\) 分别为区间 \([l,r]\) 的最大值和次大值. 区间 \([l ...
- [BZOJ 1218] [HNOI2003] 激光炸弹 【n logn 做法 - 扫描线 + 线段树】
题目链接:BZOJ - 1218 题目分析 可以覆盖一个边长为 R 的正方形,但是不能包括边界,所以等价于一个边长为 R - 1 的正方形. 坐标范围 <= 5000 ,直接 n^2 的二维前缀 ...
- BZOJ 2584: [Wc2012]memory(扫描线+线段树)
题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2584 题意:给出平面n个线段,任意两个线段严格不相交,且每个线段不平行于坐标轴.移 ...
随机推荐
- Fiddler抓取HTTPS协议
HTTPS协议握手过程: 1,客户端明文请求,把自己支持的非对称加密算法(用于使用CA证书公钥加密计算生成协商密钥的随机数per_master).对称加密算法(用于以后使用协商密钥加密传输内容).验证 ...
- linux安装lamp
github https://github.com/zblogcn/zblogphp Installation If your server system: CentOS yum -y install ...
- Python简单的制作图片验证码
-人人可以学Python--这里示范的验证码都是简单的,你也可以把字符扭曲 人人可以学Python.png Python第三方库无比强大,PIL 是python的一个d第三方图片处理模块,我们也可以使 ...
- 实现点击页面其他地方,隐藏div(vue)
方法一: 通过监听事件 document.addEventListener('click',function(e){ if(e.target.className!='usermessage'){ th ...
- RabbitMQ 基础知识
1. 背景 RabbitMQ 是一个由 erlang 开发的AMQP 开源实现,erlang语言天生具备高并发的特性,而且他的管理界面用起来十分方便. 基础概念 讲解基础概念的前面,我们先来整体构造一 ...
- tab切换 jQuery
$('p.guidan-load1').click(function(){ $("p.guidan-load1").removeClass("guidan-load12& ...
- 使用js获取url里的指定参数
String.prototype.getQuery = function(name){ var reg = new RegExp("(^|&)"+ name +&q ...
- jQuery实现,动态自动定位弹窗。JS分页,Ajax请求
工作中碰到一个问题,一个页面中碰到多个地方需要弹窗数据. 网上找了一圈,没有找到合适的,所以自己写了一个. 兼容IE7+,chrome.其它未测试. 需求:点击任意的输入框(也可其它元素,代码中有注释 ...
- 《逐梦旅程 WINDOWS游戏编程之从零开始》笔记7——DirectInput&纹理映射
第15章 DirectInput接口 DirectInput作为DirectX的组件之一,依然是一些COM对象的集合.DirectInput由IDirectinput8.IDirectInputDev ...
- Search Insert Position——二分法
Given a sorted array and a target value, return the index if the target is found. If not, return the ...