Find the median(线段树+离散化)(2019牛客暑期多校训练营(第七场))
题目出处:Find the median



示例:
输入:
5
3 1 4 1 5 9
2 7 1 8 2 9
输出:3 4 5 4 5
说明:L = [3, 2 ,4, 1, 7],R = [4, 8, 8, 3, 9]
题意:每次插入[l[i],r[i]][l[i],r[i]],询问中位数
题解:线段树模版题+离散化(不懂或忘了这些的先补充下知识)。线段树的区间操作。但是由于范围太大,需要离散化,所以就出现了连续性的问题。所以只能用线段树维护 左闭右开 即:[w[l],w[r])。
code:
#include<bits/stdc++.h>
#define LL long long
using namespace std;
const int maxx=8e6+;
LL summ[maxx],w[maxx],lz[maxx];
void pushdown(int l,int r,int root)
{
if(lz[root]){
int mid=(l+r)>>;
summ[root<<]+=(w[mid]-w[l])*lz[root];
summ[root<<|]+=(w[r]-w[mid])*lz[root];
lz[root<<]+=lz[root],lz[root<<|]+=lz[root];
lz[root]=;
}
}
void update(int l,int r,int root,int L,int R)
{
if(L<=l&&r-<=R){//更新区间[w[l],w[r]]
lz[root]++;//将一大段加入每个点加入的数储存,未用的不下放
summ[root]+=w[r]-w[l];
return ;
}
pushdown(l,r,root);//下放lz标记储存的数
int mid=(l+r)>>;
if(L<mid)update(l,mid,root<<,L,R);
if(R>=mid)update(mid,r,root<<|,L,R);
summ[root]=summ[root<<]+summ[root<<|];
}
LL query(int l,int r,int root,LL k)
{
if(l+==r){//当l+1=r时,表示当前最小的一段区间,该区间的数的个数一定相等
LL lo=summ[root]/(w[r]-w[l]);
return w[l]+(k-)/lo;
}
pushdown(l,r,root);//下发lz标记储存的数
int mid=(l+r)>>;
if(summ[root<<]>=k)return query(l,mid,root<<,k);
else return query(mid,r,root<<|,k-summ[root<<]);
}
LL n,tot=,A1,A2,B1,B2,C1,C2,M1,M2;
LL x[maxx],y[maxx],_l[maxx],_r[maxx];
int main()
{
scanf("%lld",&n);
scanf("%lld%lld%lld%lld%lld%lld",&x[],&x[],&A1,&B1,&C1,&M1);
scanf("%lld%lld%lld%lld%lld%lld",&y[],&y[],&A2,&B2,&C2,&M2);
for(int i=;i<=n;i++)//按题意算出xi、yi的值
x[i]=(A1*x[i-]+B1*x[i-]+C1)%M1,y[i]=(A2*y[i-]+B2*y[i-]+C2)%M2;
for(int i=;i<=n;i++){//按题意处理左右区域和储存所有点以便后面离散化
_l[i]=min(x[i],y[i])+,_r[i]=max(x[i],y[i])+;//为了得到一个较好的操作区间
w[tot++]=_l[i],w[tot++]=_r[i];
}
sort(w+,w+tot);//排序
tot=unique(w+,w+tot)-w;//离散化去除重复点
LL sum=;//统计第几次加入点后点的总数
for(int i=;i<=n;i++){
int l=lower_bound(w+,w+tot,_l[i])-w;//
int r=lower_bound(w+,w+tot,_r[i])-w;
update(,tot,,l,r-);//在线段树中加入一段新的数据
sum+=w[r]-w[l];
printf("%lld\n",query(,tot,,(sum+)/));//查询第i段数据加入后的中位数
}
return ;
}
Find the median(线段树+离散化)(2019牛客暑期多校训练营(第七场))的更多相关文章
- 2019牛客暑期多校训练营(第一场)I dp+线段树
题意 给出n个点,每个点有a,b两个属性,让你从左下角到右上角划一条线,线的左边每个点的贡献是\(a_i\),线的右边每个点的贡献是\(b_i\),使得两部分的总和最大. 分析 找一条折线将点分割开, ...
- DP+线段树维护矩阵(2019牛客暑期多校训练营(第二场))--MAZE
题意:https://ac.nowcoder.com/acm/contest/882/E 给你01矩阵,有两种操作:1是把一个位置0变1.1变0,2是问你从第一行i开始,到最后一行j有几种走法.你只能 ...
- Points Division(线段树+DP)2019牛客暑期多校训练营(第一场)
题意:https://ac.nowcoder.com/acm/contest/881/I 给你n个平面上的点,每个点有a.b两个权值,现在让你划分成两个区域(要求所有A集合里的点不能在任何B集合里的点 ...
- 2019牛客暑期多校训练营(第二场)E 线段树维护dp转移矩阵
题意 给一个\(n\times m\)的01矩阵,1代表有墙,否则没有,每一步可以从\(b[i][j]\)走到\(b[i+1][j]\),\(b[i][j-1]\),\(b[i][j+1]\),有两种 ...
- 2019牛客暑期多校训练营(第九场)H Cutting Bamboos(主席树+二分)
题意:n个竹子,有高度,q次询问,询问之间是独立的,每次查询输入l,r,x,y代表砍区间[l,r]]内的竹子砍y次,最后一次要砍成0,每次砍掉的总长度相同,问第x次砍的高度是多少. 既然每次要求砍掉的 ...
- 2019牛客暑期多校训练营(第二场)-E MAZE
题目链接:https://ac.nowcoder.com/acm/contest/882/E 题意:n×m的矩阵,0表示可以走,1表示墙,不能通过.有q中操作,一种是改变坐标(x,y)的状态,一种是询 ...
- 2019牛客暑期多校训练营(第九场)A:Power of Fibonacci(斐波拉契幂次和)
题意:求Σfi^m%p. zoj上p是1e9+7,牛客是1e9: 对于这两个,分别有不同的做法. 前者利用公式,公式里面有sqrt(5),我们只需要二次剩余求即可. 后者mod=1e9,5才 ...
- 2019牛客暑期多校训练营(第一场)A题【单调栈】(补题)
链接:https://ac.nowcoder.com/acm/contest/881/A来源:牛客网 题目描述 Two arrays u and v each with m distinct elem ...
- 2019牛客暑期多校训练营(第一场) B Integration (数学)
链接:https://ac.nowcoder.com/acm/contest/881/B 来源:牛客网 Integration 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 5242 ...
- 2019牛客暑期多校训练营(第一场) A Equivalent Prefixes ( st 表 + 二分+分治)
链接:https://ac.nowcoder.com/acm/contest/881/A 来源:牛客网 Equivalent Prefixes 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/ ...
随机推荐
- vue中代理实现方法
vue中代理实现方法如下: const path = require('path'); function resolve(dir) { return path.join(__dirname, dir) ...
- dbt 0.14.0 试用
dbt 0.14.0 在最近已经发布了,dbt server 的还是很不错的特性,以下安装试用下几个新功能 环境准备 安装 如果没有安装的: pip install dbt 已经安装的: pip in ...
- 使用gitbase 分析git 仓库代码
gitbase 是一个基于golang 开发的开源git 仓库sql 接口查询引擎,基于此工具,我们可以方便的分析git 仓库代码的情况 而且可以基于源码的分析,还是很强大的 安装 直接使用编译的 ...
- 羊村的OI题解
目录 喜羊羊与灰太狼--仓库管理 喜羊羊与灰太狼--破译密码 喜羊羊与灰太狼--烦恼的礼物 喜羊羊与灰太狼--仓库管理 传送门 水的一批,还让开o2了 就不写了 #include<iostrea ...
- 洛谷P1043数字游戏
题目 区间DP,将\(maxn[i][j][k]\)表示为i到j区间内分为k个区间所得到的最大值,\(minn\)表示最小值. 然后可以得到状态转移方程: \[maxn[i][j][k]= max(m ...
- git:GitLab代码回滚到特定版本
在当前branch上多次commit代码并且push后,发现不符合要求,需要回滚到特定的版本.步骤如下: 1.查找commitId (1)用命令行打开git项目路径,输入git log命令查看comm ...
- 设计模式——<面向对象设计原则以及23种设计模式分类>
一.面向对象八大设计原则: 1.依赖倒置原则(DIP) 高层模块(稳定)不应该依赖于低层模块(变化),二者都应该依赖于抽象(稳定) . 抽象(稳定)不应该依赖于实现细节(变化) ,实现细节应该依赖于抽 ...
- (转载)ranger原理
文章目录 一.业务背景 现状&&需求 二.大数据安全组件介绍与对比 1.Kerberos 2.Apache Sentry 3.Apache Ranger 4.为什么我们选择Ranger ...
- fillter根据value来匹配字段
字段对应 let cashBackState = { 'WAIT_FIVE': '满5单可返现', 'FINISHED': '已返现' } filters: { cashBackStateFilter ...
- vue 创建监听,和销毁监听(addEventListener, removeEventListener)
最近在做一个有关监听scroll的功能, 发现我添加监听之后一直不起作用: 1 2 mounted() { window.addEventListener("scroll" ...