终于是解决了这个题目了

不过不知道下一次碰到主席树到底做不做的出来,这个东西稍微难一点就不一定能做得出

离散化+扫描线式的建树,所以对于某个坐标二分找到对应的那颗主席树,即搜索出结果即可(因为是扫描线式的建树,找到对应的树之后,就知道该点上面的线段有多少条了)

其他就是普通主席树的操作了

主席树里面维护两个东西,一个就是普通的那种在该区间的节点数目,另外就是权值

#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 主席树+扫描线的更多相关文章

  1. HDU 4866 Shooting 题解:主席树

    这题的主要的坑点就是他给你的射击目标有重合的部分,如果你向这些重合的部分射击的话要考虑两种情况: 射击目标数量 ≥ 重合数量 : 全加上 射击目标数量 ≤ 重合数量 : 只加距离*射击目标数量 然而这 ...

  2. HDU 4417 Super Mario(主席树求区间内的区间查询+离散化)

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

  3. POJ 2104&HDU 2665 Kth number(主席树入门+离散化)

    K-th Number Time Limit: 20000MS   Memory Limit: 65536K Total Submissions: 50247   Accepted: 17101 Ca ...

  4. hdu 4417 Super Mario (主席树)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=4417 题意: 给你段长为n的序列,有q个询问,每次询问区间[l.r]内有多少个数小于等于k 思路: 之前用 ...

  5. hdu 4348 To the moon (主席树)

    版权声明:本文为博主原创文章,未经博主允许不得转载. hdu 4348 题意: 一个长度为n的数组,4种操作 : (1)C l r d:区间[l,r]中的数都加1,同时当前的时间戳加1 . (2)Q ...

  6. HDU 4348 To the moon 主席树 在线更新

    http://acm.hdu.edu.cn/showproblem.php?pid=4348 以前做的主席树没有做过在线修改的题做一下(主席树这种东西正经用法难道不是在线修改吗),标记永久化比较方便. ...

  7. HDU 1264 Counting Squares (线段树-扫描线-矩形面积并)

    版权声明:欢迎关注我的博客.本文为博主[炒饭君]原创文章,未经博主同意不得转载 https://blog.csdn.net/a1061747415/article/details/25471349 P ...

  8. HDU 4419 Colourful Rectangle --离散化+线段树扫描线

    题意: 有三种颜色的矩形n个,不同颜色的矩形重叠会生成不同的颜色,总共有R,G,B,RG,RB,GB,RGB 7种颜色,问7种颜色每种颜色的面积. 解法: 很容易想到线段树扫描线求矩形面积并,但是如何 ...

  9. HDU 2665 && POJ 2104(主席树)

    http://poj.org/problem?id=2104 对权值进行建树(这个时候树的叶子是数组b的有序数列),然后二分查找原数列中每个数在有序数列中的位置(即第几小),对每一个前缀[1,i]建一 ...

随机推荐

  1. winform跳转到bs

    private void button7_Click(object sender, EventArgs e) { System.Diagnostics.Process.Start("http ...

  2. NoSQL 是什么

    NoSQL 全称 Not only SQL ,是一种相对较新的数据库设计方式,传统的关系型数据库使用的是固定模式,并将数据分割在多个表中,然而,对于大数据集的情况,数据量太大使其难以存放在单一的服务器 ...

  3. jquery的优点

    轻量级 JQuery非常轻巧,采用Dean Edwards编写的Packer压缩后,大小不到30KB,如果使用Min版并且在服务器端启用Gzip压缩后,大小只有18KB. 强大的选择器 JQuery允 ...

  4. mybatis关键查询

    一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关 ...

  5. zookeeper logs is missing zookeeper 日志丢失

    ERROR [main:QuorumPeerMain@85] - Invalid config, exiting abnormally Invalid config, exiting abnormal ...

  6. Linux centos7日常运维——监控io性能、free内存命令、ps进程命令、查看网络状态、linux下抓包

    一.监控io性能 Linux系统出现了性能问题,一般我们可以通过top.iostat.free.vmstat等命令来查看初步定位问题.其中iostat可以给我们提供丰富的IO状态数据. iostat ...

  7. redis中关闭rdb跟aof

    https://zm10.sm-tc.cn/?src=l4uLj8XQ0IiIiNGdip2KlJDRnJCS0JaRmZCbmouelpPSzc%2FJz8vJxtGXi5KT&uid=49 ...

  8. Gcd&Exgcd

    欧几里得算法: \[gcd(a,b)=gcd(b,a\bmod b)\] 证明: 显然(大雾) 扩展欧几里得及证明: 为解决一个形如 \[ax+by=c\] 的方程. 根据裴蜀定理,当且仅当 \[gc ...

  9. 2019护网杯baby_forensic

    题目名称:baby_forensic题目描述:can you catch the flag?附件:“data.7z” 2019护网杯初赛的一道取证题,比赛时没做出来,赛后又研究了一下. 获取profi ...

  10. Day3-N - Monthly Expense POJ3273

    Farmer John is an astounding accounting wizard and has realized he might run out of money to run the ...