我们可以先离散化,然后建立权值的可持久化线段树,记录每个数出现的次数,对于区间询问直接判断左右儿子的cnt是不是大于(r-k+1)/2,然后递归到最后一层要是还是大于就有,否则不存在。

  反思:挺简单一道题调了一个晚上加一个几节课= =,原因是这道题的空间给的是128MB,那么就会有比较严重的卡空间的地方,开始我的线段树是记录的左右儿子和代表的区间,这样会MLE,那么我们可以不记录代表的区间然后递归的时候传上去区间也可以起到同样的效果。

/**************************************************************
    Problem: 3524
    User: BLADEVIL
    Language: C++
    Result: Accepted
    Time:7392 ms
    Memory:125808 kb
****************************************************************/
 
//By BLADEVIL
#include <cstdio>
#include <cstring>
#include <algorithm>
#define maxn 500010
 
using namespace std;
 
struct segment {
    int cnt;
    int son[];
    segment() {
        cnt=;
        memset(son,,sizeof son);
    }
}t[];
 
struct rec {
    int num,key;
}a[maxn];
 
int n,m,tot;
int rot[maxn],ans[maxn];
 
bool cmp1(rec x,rec y) {
    return x.key<y.key;
}
 
bool cmp2(rec x,rec y) {
    return x.num<y.num;
}
 
void build(int &x,int l,int r) {
    if (!x) x=++tot;
    if (l==r) return ;
    int mid=l+r>>;
    build(t[x].son[],l,mid); build(t[x].son[],mid+,r);
    return ;
}
 
void insert(int &x,int rot,int key,int l,int r) {
    if (!x) x=++tot;
    if (l==r) {
        t[x].cnt=t[rot].cnt+; return ;
    }
    int mid=l+r>>;
    if (key>mid) {
        t[x].son[]=t[rot].son[];
        insert(t[x].son[],t[rot].son[],key,mid+,r);
    } else {
        t[x].son[]=t[rot].son[];
        insert(t[x].son[],t[rot].son[],key,l,mid);
    }
    t[x].cnt=t[rot].cnt+;
    return ;
}
 
int query(int lx,int rx,int key,int l,int r) {
    //printf("%d %d %d\n",lx,rx,key);
    if (l==r) return l;
    int mid=l+r>>;
    if (t[t[rx].son[]].cnt-t[t[lx].son[]].cnt>key) return query(t[lx].son[],t[rx].son[],key,l,mid); else
    if (t[t[rx].son[]].cnt-t[t[lx].son[]].cnt>key) return query(t[lx].son[],t[rx].son[],key,mid+,r); else
        return ;
}
 
int main() {
    //freopen("kur.in","r",stdin); freopen("kur.out","w",stdout);
    scanf("%d%d",&n,&m);
    for (int i=;i<=n;i++) scanf("%d",&a[i].key),a[i].num=i;
    sort(a+,a++n,cmp1);
    int j=; ans[]=a[].key;
    for (int i=,cur=a[].key;i<=n;i++)
        if (a[i].key==cur) a[i].key=j; else cur=a[i].key,a[i].key=++j,ans[j]=cur;
    //for (int i=1;i<=n;i++) printf("%d %d\n",a[i].num,a[i].key);
    sort(a+,a++n,cmp2);
    build(rot[],,j);
    for (int i=;i<=n;i++) insert(rot[i],rot[i-],a[i].key,,j);
    //for (int i=1;i<=tot;i++) printf("%d %d %d %d %d %d\n",i,t[i].left,t[i].right,t[i].son[0],t[i].son[1],t[i].cnt);
    while (m--) {
        int l,r; scanf("%d%d",&l,&r);
        if (l>r) swap(l,r);
        printf("%d\n",ans[query(rot[l-],rot[r],(r-l+)/,,j)]);
    }
    //fclose(stdin); fclose(stdout);
    return ;
}

学长给了一个随机算法,虽然参数改了不是T就是WA,还是觉得挺有纪念意义的= =。

//By BLADEVIL
#include <ctime>
#include <cstdio>
#include <vector>
#include <cstdlib>
#define maxn 500010
#define k 10 using namespace std; int n,m;
int a[maxn];
vector<int>rot[maxn]; int calc(int x,int y) {
int l=,r=rot[x].size()-;
int ans=;
while (l<=r) {
int mid=l+r>>;
//printf("%d %d %d\n",l,r,mid);
if (rot[x][mid]<=y) ans=mid,l=mid+; else r=mid-;
}
return ans;
} int judge(int x,int l,int r) {
int a1=calc(x,l),a2=calc(x,r);
int ans=a2-a1+;
if (rot[x][a1]!=l) ans--;
return ans;
} int main() {
//freopen("kur.in","r",stdin); freopen("kur.out","w",stdout);
srand((int)time(NULL));
/*
scanf("%d",&n);
for (int i=1;i<=n;i++) scanf("%d",&a[i]);
for (int i=1;i<=n;i++) rot[1].push_back(a[i]);
scanf("%d",&m);
printf("%d\n",calc(1,m));
return 0;
*/
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++) scanf("%d",&a[i]);
for (int i=;i<=n;i++) rot[a[i]].push_back(i);
while (m--) {
int l,r; scanf("%d%d",&l,&r);
for (int i=;i<=k;i++) {
int cur=l+rand()%(r-l+);
if (judge(a[cur],l,r)>(r-l+)/) {
printf("%d\n",a[cur]); l=r=-;
break;
}
}
if (l!=-) printf("0\n");
}
fclose(stdin); fclose(stdout);
return ;
}

bzoj 3524 可持久化线段树的更多相关文章

  1. bzoj 3123 可持久化线段树启发式合并

    首先没有连边的操作的时候,我们可以用可持久化线段树来维护这棵树的信息,建立权值可持久化线段树,那么每个点继承父节点的线段树,当询问为x,y的时候我们可以询问rot[x]+rot[y]-rot[lca( ...

  2. bzoj 3207 可持久化线段树

    首先因为固定询问长度,所以我们可以将整个长度为n的数列hash成长度为n-k+1的数列,每次询问的序列也hash成一个数,然后询问这个数是不是在某个区间中出现过,这样我们可以根据初始数列的权值建立可持 ...

  3. bzoj 3207 可持久化线段树+hash

    这道题要看出来这个做法还是比较容易说一下细节 1.因为要用hash的区间值域来建树,而hash为了不冲突要开的很大,所以值域就会比较的大,不过这道题好的一点是没有修改,所以直接离散一下就会小很多 2. ...

  4. BZOJ 2588: Spoj 10628. Count on a tree-可持久化线段树+LCA(点权)(树上的操作) 无语(为什么我的LCA的板子不对)

    2588: Spoj 10628. Count on a tree Time Limit: 12 Sec  Memory Limit: 128 MBSubmit: 9280  Solved: 2421 ...

  5. 【BZOJ 3524】【Poi2014】Couriers 可持久化线段树

    为什么这个主席树叫可持久化线段树,我不知道,具体得问达神.我无限T,然后DaD3zZ一针见血地指出了我的N*50爆内存导致无限编译超时O)ZO)ZO)Z真是太神啦.以图为鉴: 达神题解传送门:http ...

  6. [BZOJ 3218] A + B Problem 【可持久化线段树 + 网络流】

    题目连接:BZOJ - 3218 题目分析 题目要求将 n 个点染成黑色或白色,那么我们可以转化为一个最小割模型. 我们规定一个点 i 最后属于 S 集表示染成黑色,属于 T 集表示染成白色,那么对于 ...

  7. [BZOJ 3207] 花神的嘲讽计划Ⅰ【Hash + 可持久化线段树】

    题目链接:BZOJ - 3207 题目分析 先使用Hash,把每个长度为 k 的序列转为一个整数,然后题目就转化为了询问某个区间内有没有整数 x . 这一步可以使用可持久化线段树来做,虽然感觉可以有更 ...

  8. BZOJ.4771.七彩树(可持久化线段树)

    BZOJ 考虑没有深度限制,对整棵子树询问怎么做. 对于同种颜色中DFS序相邻的两个点\(u,v\),在\(dfn[u],dfn[v]\)处分别\(+1\),\(dfn[LCA(u,v)]\)处\(- ...

  9. BZOJ.2653.[国家集训队]middle(可持久化线段树 二分)

    BZOJ 洛谷 求中位数除了\(sort\)还有什么方法?二分一个数\(x\),把\(<x\)的数全设成\(-1\),\(\geq x\)的数设成\(1\),判断序列和是否非负. 对于询问\(( ...

随机推荐

  1. TCP 接收窗口自动调节

    https://technet.microsoft.com/zh-cn/magazine/2007.01.cableguy.aspx 欢迎来到 TechNet 杂志“网络专家”的第一部分.TechNe ...

  2. python实现post请求

    今天无论如何都要留下一些什么东西... 可以说今天学到一个新的一个东西,也需要分享出来,给更多的人去使用. 今天爬取的数据里面是客户端向服务器端发送加密过的token和一些页码之类的一个数据.(我主要 ...

  3. 图像检测算法Halcon 10的使用

    安装完成HALCON之后,在VS项目中添加动态链接库配置项目,并修改此项目属性的包含目录.库目录和链接器.

  4. C# 知识回顾 - 扩展方法解析

    在使用面向对象的语言进行项目开发的过程中,较多的会使用到“继承”的特性,但是并非所有的场景都适合使用“继承”特性,在设计模式的一些基本原则中也有较多的提到. 继承的有关特性的使用所带来的问题:对象的继 ...

  5. COM 自动化控制Excel应用程序

    class Program { static void Main(string[] args) { var dt = new System.Data.DataTable(); dt.Columns.A ...

  6. iOS开发UI篇—transframe属性(形变)

    iOS开发UI篇—transframe属性(形变) 1. transform属性 在OC中,通过transform属性可以修改对象的平移.缩放比例和旋转角度 常用的创建transform结构体方法分两 ...

  7. bzoj3992-序列统计

    给出\(n,m,x,S\),其中\(S\subseteq [0,m)\),问有多少个长度为\(n\)的数列\(a\)使得\(a_i\in S\),并且数列中所有元素的乘积mod \(m\)为\(x\) ...

  8. CentOS 双网卡绑定实现平衡负载

    绑定两块网卡主要为了解决网卡故障.负载均衡等问题. 1.在vm加一块网卡,登录后检查网卡是否识别. 分别用ip addr和nmcli查看网卡的情况 [root@bigdata-senior01 ~]# ...

  9. [LOJ2538] [PKUWC2018] Slay the Spire

    题目链接 LOJ:https://loj.ac/problem/2538 Solution 计数好题. 首先可以发现这题和期望没关系. 其次对于手上的一套牌,设我们有\(a\)张强化牌,那么: 如果\ ...

  10. 【BZOJ3240】【NOI2013】矩阵游戏(数论)

    [BZOJ3240][NOI2013]矩阵游戏(数论) 题面 BZOJ 题解 搞什么矩阵十进制快速幂加卡常? 直接数学推导不好吗? 首先观察如何从每一行的第一个推到最后一个 \(f[i]=a·f[i- ...