题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4747

题意:给出一个数列A。计算所有的mex(i,j)之和。1<=i<=j<=n。

思路:从前向后依次统计以该位置为左端点的区间之和。那么现在我们考虑i计算之后后面的变化。考虑极端情况,若i位置之后的所有数字都大于i,那么i计算之后后面的所有数对的mex值起码为A[i]。那么,我们记录i之后数字A[i]出现的最早位置next[i],每次用A[i]更新[i+1,next[i]-1]这个区间即可。

struct node
{
    int L,R,Max,Min,det;
    i64 sum;
    
    void set(int x)
    {
        det=x;
        Max=Min=x;
        sum=(i64)(R-L+1)*x;
    }
};

node a[N<<2];
int d[N],next[N],p[N],b[N];
int n;

void pushUp(int t)
{
    if(a[t].L==a[t].R) return;
    a[t].sum=a[t*2].sum+a[t*2+1].sum;
    a[t].Min=min(a[t*2].Min,a[t*2+1].Min);
    a[t].Max=max(a[t*2].Max,a[t*2+1].Max);
}

void pushDown(int t)
{
    if(a[t].L==a[t].R) return;
    int M=(a[t].L+a[t].R)>>1;
    if(a[t].det>0)
    {
        a[t*2].set(a[t].det);
        a[t*2+1].set(a[t].det);
        a[t].det=0;
    }
}

void build(int t,int L,int R)
{
    a[t].L=L;
    a[t].R=R;
    a[t].det=0;
    if(L==R)
    {
        a[t].Max=a[t].Min=a[t].sum=b[L];
        return;
    }
    int M=(L+R)>>1;
    build(t*2,L,M);
    build(t*2+1,M+1,R);
    pushUp(t);
}

void update(int t,int L,int R,int x)
{
    if(L<=a[t].L&&a[t].R<=R&&x<a[t].Min)
    {
        a[t].set(x);
        return;
    }
    pushDown(t);
    int M=(a[t].L+a[t].R)>>1;
    if(M>=L&&a[t*2].Max>x) update(t*2,L,R,x);
    if(M<R&&a[t*2+1].Max>x) update(t*2+1,L,R,x);
    pushUp(t);
}

int main()
{
    Rush(n)
    {
        if(n==0) break;
        int i,j=0;
        clr(p,0);
        FOR1(i,n) 
        {
            RD(d[i]);
            if(d[i]>n) d[i]=n+1;
            p[d[i]]=1;
            while(p[j]) j++;
            b[i]=j;
        }
        for(i=0;i<=n+1;i++) p[i]=n+1;
        for(i=n;i>=1;i--)
        {
            next[i]=p[d[i]];
            p[d[i]]=i;
        }
        build(1,1,n);
        i64 ans=a[1].sum;
        FOR1(i,n)
        {
            if(i+1<=next[i]-1) update(1,i+1,next[i]-1,d[i]);
            update(1,i,i,0);
            ans+=a[1].sum;
        }
        printf("%I64d\n",ans);
    }
}

HDU 4747 Mex(线段树)的更多相关文章

  1. hdu 4747 mex 线段树+思维

    http://acm.hdu.edu.cn/showproblem.php?pid=4747 题意: 我们定义mex(l,r)表示一个序列a[l]....a[r]中没有出现过得最小的非负整数, 然后我 ...

  2. hdu 4747 Mex( 线段树? 不,区间处理就行(dp?))

    Mex Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submis ...

  3. HDU 4747 Mex ( 线段树好题 + 思路 )

    参考:http://www.cnblogs.com/oyking/p/3323306.html 相当不错的思路,膜拜之~ 个人理解改日补充. #include <cstdio> #incl ...

  4. hdu 4747【线段树-成段更新】.cpp

    题意: 给出一个有n个数的数列,并定义mex(l, r)表示数列中第l个元素到第r个元素中第一个没有出现的最小非负整数. 求出这个数列中所有mex的值. 思路: 可以看出对于一个数列,mex(r, r ...

  5. hdu 4031 attack 线段树区间更新

    Attack Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Others)Total Subm ...

  6. hdu 4288 离线线段树+间隔求和

    Coder Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  7. hdu 3016 dp+线段树

    Man Down Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  8. HDU 4747 Mex 递推/线段树

    题目链接: acm.hdu.edu.cn/showproblem.php?pid=4747 Mex Time Limit: 15000/5000 MS (Java/Others)Memory Limi ...

  9. HDU 4747 Mex (2013杭州网络赛1010题,线段树)

    Mex Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submis ...

  10. HDU 4747 Mex(线段树)(2013 ACM/ICPC Asia Regional Hangzhou Online)

    Problem Description Mex is a function on a set of integers, which is universally used for impartial ...

随机推荐

  1. BitMap排序

    问题描述:       BitMap排序思想:             用1bit位标记某个元素对应的值       优点:             效率高,不允许进行比较和移位            ...

  2. secure CRT记住密码不可用

    secure CRT 记住密码,琢磨好几天了. 终于发现要在软件打开的时候设置了密码才能让每个会话记住密码. 一直懒得在打开软件的时候设置密码,结果每次打开会话都要输入密码...为了省下输入一次密码, ...

  3. Nodejs Express 4.X 中文API 4--- Router篇

    相关阅读: Express 4.X API 翻译[一] --  Application篇 Express4.XApi 翻译[二] --  Request篇 Express4.XApi 翻译[三] -- ...

  4. TLS学习总结

    我们有知道 Immunity Debugger,OD 调试器,在调试程序时会设断在OEP(修改第一个字节0xcc).我在想,使用什么编程技术,代码可以在OEP前被执行.在网上找了些资料,在论坛上看到许 ...

  5. Http Module 介绍

    引言 Http 请求处理流程 和 Http Handler 介绍 这两篇文章里,我们首先了解了Http请求在服务器端的处理流程,随后我们知道Http请求最终会由实现了IHttpHandler接口的类进 ...

  6. 理解Linux系统负荷[转]

    一.查看系统负荷 在Linux系统中,我们一般使用uptime命令查看(w命令和top命令也行).(另外,它们在苹果公司的Mac电脑上也适用.)   二.一个类比 我们不妨把这个CPU想象成一座大桥, ...

  7. 利用Linq + Jquery + Ajax 异步分页的实现

    在Web显示的时候我们经常会遇到分页显示,而网上的分页方法甚多,但都太过于消耗带宽,所以我想到了用Ajax来分页,利用返回的Json来处理返回的数据, 大大简化了带宽的压力. 先说下思路,无非就是异步 ...

  8. Sqli-labs less 25

    Less-25 本关主要为or and过滤,如何绕过or和and过滤.一般性提供以下几种思路: 大小写变形 Or,OR,oR 编码,hex,urlencode 添加注释/*or*/ 利用符号 and= ...

  9. CentOS 6下安装nginx

    原文:http://yubosun.akhtm.com/tech/centos-nginx.htm 1 在nginx官方网站下载一个rpm包,下载地址是:http://nginx.org/en/dow ...

  10. 如何使用 OneAPM 监控微软 Azure Cloud Service ?

    不知不觉微软 Azure 已经进入中国市场近两年的时间.那么 Azure 平台的性能究竟如何?资源加载的延迟.虚拟机的稳定性等问题是否切实满足客户期许.这些都是大家对微软 Azure 这个国外的云服务 ...