HDU 4866 多校1 主席树+扫描线
终于是解决了这个题目了
不过不知道下一次碰到主席树到底做不做的出来,这个东西稍微难一点就不一定能做得出
离散化+扫描线式的建树,所以对于某个坐标二分找到对应的那颗主席树,即搜索出结果即可(因为是扫描线式的建树,找到对应的树之后,就知道该点上面的线段有多少条了)
其他就是普通主席树的操作了
主席树里面维护两个东西,一个就是普通的那种在该区间的节点数目,另外就是权值
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define LL __int64
using namespace std;
const int N =200010;
const int maxn=N*100;
int n,m,x,p,tot;
int t[N],T[N];
int c1[maxn],lson[maxn],rson[maxn];
LL c2[maxn];
struct node2
{
int h,id;
bool operator < (const node2 rhs) const
{
return h<rhs.h;
}
}y[N];
struct node
{
int d,h,id;
bool operator < (const node& rhs)const{
if (d!=rhs.d) return d<rhs.d;
else return h>rhs.h;
}
}seg[N];
int build(int l,int r)
{
int rt=++tot;
c1[rt]=c2[rt]=0;
if (l>=r) return rt;
int mid=(l+r)>>1;
lson[rt]=build(l,mid);
rson[rt]=build(mid+1,r);
return rt;
}
int inserts(int rt,int pos,int v1,LL v2)
{
int newrt=++tot;
int tmp=newrt;
c1[newrt]=c1[rt]+v1;
c2[newrt]=c2[rt]+v2;
int l=1,r=n;
while (l<r)
{
int mid=(l+r)>>1;
if (pos<=mid){
lson[newrt]=++tot;
rson[newrt]=rson[rt];
newrt=lson[newrt];
rt=lson[rt];
r=mid;
}
else{
rson[newrt]=++tot;
lson[newrt]=lson[rt];
newrt=rson[newrt];
rt=rson[rt];
l=mid+1;
}
c1[newrt]=c1[rt]+v1;
c2[newrt]=c2[rt]+v2;
}
return tmp;
}
LL query(int rt,int pos)
{
LL ret=0;
int l=1,r=n;
while (l<r)
{
int mid=(l+r)>>1;
if (c1[lson[rt]]>=pos){
r=mid;
rt=lson[rt];
}
else
{
pos-=c1[lson[rt]];
ret+=c2[lson[rt]];
rt=rson[rt];
l=mid+1;
}
}
return c2[rt]+ret;
}
int main()
{
int loc,a,b,c;
while (scanf("%d%d%d%d",&n,&m,&x,&p)!=EOF)
{
int cnt=0;
tot=0;
for (int i=1;i<=n;i++){
scanf("%d%d%d",&a,&b,&c);
y[i].h=c;
y[i].id=i;
seg[++cnt]=(node){a,c,i};
seg[++cnt]=(node){b,-c,i};
}
sort(seg+1,seg+1+cnt);
sort(y+1,y+1+n);
for (int i=1;i<=n;i++){
t[y[i].id]=i;
}
T[0]=build(1,n);
for (int i=1;i<=cnt;i++){
if (seg[i].h>=0)
T[i]=inserts(T[i-1],t[seg[i].id],1,seg[i].h);
else
T[i]=inserts(T[i-1],t[seg[i].id],-1,seg[i].h);
}
LL pre=1;
while (m--)
{
scanf("%d%d%d%d",&loc,&a,&b,&c);
int K;
K=(a%c*pre%c+b)%c;
if (K==0){
puts("0");
pre=0;
continue;
}
int id;
int l=1,r=cnt+1;
while (l<r)
{
int mid=(l+r)>>1;
if (seg[mid].d<loc || (seg[mid].d==loc && seg[mid].h>=0)){
id=mid;
l=mid+1;
}
else{
r=mid;
}
}
LL ans=query(T[id],K);
if (pre>p) ans*=2;
pre=ans;
printf("%I64d\n",ans);
}
}
return 0;
}
HDU 4866 多校1 主席树+扫描线的更多相关文章
- HDU 4866 Shooting 题解:主席树
这题的主要的坑点就是他给你的射击目标有重合的部分,如果你向这些重合的部分射击的话要考虑两种情况: 射击目标数量 ≥ 重合数量 : 全加上 射击目标数量 ≤ 重合数量 : 只加距离*射击目标数量 然而这 ...
- HDU 4417 Super Mario(主席树求区间内的区间查询+离散化)
Super Mario Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- POJ 2104&HDU 2665 Kth number(主席树入门+离散化)
K-th Number Time Limit: 20000MS Memory Limit: 65536K Total Submissions: 50247 Accepted: 17101 Ca ...
- hdu 4417 Super Mario (主席树)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=4417 题意: 给你段长为n的序列,有q个询问,每次询问区间[l.r]内有多少个数小于等于k 思路: 之前用 ...
- hdu 4348 To the moon (主席树)
版权声明:本文为博主原创文章,未经博主允许不得转载. hdu 4348 题意: 一个长度为n的数组,4种操作 : (1)C l r d:区间[l,r]中的数都加1,同时当前的时间戳加1 . (2)Q ...
- HDU 4348 To the moon 主席树 在线更新
http://acm.hdu.edu.cn/showproblem.php?pid=4348 以前做的主席树没有做过在线修改的题做一下(主席树这种东西正经用法难道不是在线修改吗),标记永久化比较方便. ...
- HDU 1264 Counting Squares (线段树-扫描线-矩形面积并)
版权声明:欢迎关注我的博客.本文为博主[炒饭君]原创文章,未经博主同意不得转载 https://blog.csdn.net/a1061747415/article/details/25471349 P ...
- HDU 4419 Colourful Rectangle --离散化+线段树扫描线
题意: 有三种颜色的矩形n个,不同颜色的矩形重叠会生成不同的颜色,总共有R,G,B,RG,RB,GB,RGB 7种颜色,问7种颜色每种颜色的面积. 解法: 很容易想到线段树扫描线求矩形面积并,但是如何 ...
- HDU 2665 && POJ 2104(主席树)
http://poj.org/problem?id=2104 对权值进行建树(这个时候树的叶子是数组b的有序数列),然后二分查找原数列中每个数在有序数列中的位置(即第几小),对每一个前缀[1,i]建一 ...
随机推荐
- Spring mvc mybatis 查询结果缺少字段 解决方法
参考:https://blog.csdn.net/xiaofeifei8421/article/details/43231815
- Linux --xrandr command
Source: https://www.x.org/archive/current/doc/man/man1/xrandr.1.xhtml https://blog.csdn.net/syh_486_ ...
- Red_Hat yum源配置
http://www.linuxidc.com/Linux/2016-06/132171.htm
- Day4-F-产生冠军 HDU - 2094
有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打一场比赛. 球赛的规则如下: 如果A打败了B,B又打败了C,而A与C之间没有进行过比赛,那么就认定,A一定能打败C. 如果A打败了B,B又打败了 ...
- Docker 安装(centos7下)
下面链接为官方的安装方法(官方的是最好的): https://docs.docker.com/install/linux/docker-ce/centos/#upgrade-docker-after- ...
- is application failed to start because no Qt platform plugin could be initialized. Reinstalling the application may fix this problem
最近试着了解 c++,接触到了QT,写了一个测试程序,在开发环境下正常后移到非开发环境,报错 网上找资料说是少了platforms文件夹中的dll,把里面所有的dll复制到执行程序目录,还是提示,继续 ...
- GNS3 模拟icmp重定向
网关实质上是一个网络通向其他网络的IP地址.比如有网络A和网络B,网络A的IP地址范围为“192.168.1.1~192. 168.1.254”,子网掩码为255.255.255.0:网络B的IP地址 ...
- 【pwnable.tw】 alive_note
突然发现已经两个月没写过WP了,愧疚- -... 此题也算一道分数很高的题目,主要考察Shellcode的编写. 又是一道题目逻辑很简单的题. 首先提供了三个函数 查看,删除,添加 查看函数: 此函数 ...
- uboot配置和编译过程详解
根据朱有鹏老师讲解整理 一.uboot主Makefile分析 1.uboot version确定(Makefile的24-29行) include/version_autogenerated.h文件是 ...
- spring core:@AliasFor的派生性
spring对Annotation的派生性应用可谓炉火纯青,在spring core:@Component的派生性讲过支持层次上派生性,而属性上派生的需求则借助了@AliasFor,它是从spring ...