题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2752

题意:给出一个数列A,维护两种操作:

(1)将区间[L,R]之内的所有数字增加det;

(2)给出区间[L,R],在该区间内任意选出两个位置l和r(L<=l<=r<=R),[l,r]的费用为该区间的数字之和。求费用的期望。

思路:对于区间[L,R],长度len=(R-L+1),可知不同的区间种类有(len+1)*len/2种,那么接下来就是计算所有区间下的数字和的和S。我们发现:

接下来我们看对于这个S我们在修改时怎么维护它?对于区间[L,R],我们设置参数sum,Lsum,Rsum,t,p,size:

那么对于区间[L,mid],[mid+1,R]以及区间[L,R],我们设其分别为p、q、a,那么区间合并为:

对于区间增加x:

struct node
{
    int L,R;
    i64 sum,Lsum,Rsum,S,det,t,p,size;
    
    
    void add(i64 x)
    {
        det+=x;
        sum+=x*size;
        Lsum+=t*x;
        Rsum+=t*x;
        S+=x*p;
    }
};

node a[N<<2];

i64 get(i64 n)
{
    return n*(n+1)*(n+1)/2-n*(n+1)*(2*n+1)/6;
}

i64 get1(i64 n)
{
    return n*(n+1)/2;
}

void build(int t,int L,int R)
{
    a[t].L=L;
    a[t].R=R;
    a[t].size=R-L+1;
    a[t].t=get1(R-L+1);
    a[t].p=get(R-L+1);
    a[t].sum=a[t].Lsum=a[t].Rsum=a[t].S=0;
    a[t].det=0;
    if(L==R) return;
    int mid=(L+R)>>1;
    build(t*2,L,mid);
    build(t*2+1,mid+1,R);
}

void pushUp(node &a,node p,node q)
{
    if(a.L==a.R) return;
    a.sum=p.sum+q.sum;
    a.Lsum=p.Lsum+q.Lsum+q.sum*p.size;
    a.Rsum=q.Rsum+p.Rsum+p.sum*q.size;
    a.S=p.S+p.Lsum*q.size+q.S+q.Rsum*p.size;
}

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

void update(int t,int L,int R,i64 x)
{
    if(a[t].L==L&&a[t].R==R)
    {
        a[t].add(x);
        return;
    }
    pushDown(t);
    int mid=(a[t].L+a[t].R)>>1;
    if(R<=mid) update(t*2,L,R,x);
    else if(L>mid) update(t*2+1,L,R,x);
    else 
    {
        update(t*2,L,mid,x);
        update(t*2+1,mid+1,R,x);
    }
    pushUp(a[t],a[t*2],a[t*2+1]);
}

node getSum(int t,int L,int R)
{
    if(a[t].L==L&&a[t].R==R) return a[t];
    pushDown(t);
    node l,r,ans;
    int mid=(a[t].L+a[t].R)>>1;
    if(R<=mid) ans=getSum(t*2,L,R);
    else if(L>mid) ans=getSum(t*2+1,L,R);
    else 
    {
        l=getSum(t*2,L,mid);
        r=getSum(t*2+1,mid+1,R);
        ans.L=L;
        ans.R=R;
        ans.size=R-L+1;
        pushUp(ans,l,r);
    }
    pushUp(a[t],a[t*2],a[t*2+1]);
    return ans;
}

int n,m;

i64 Gcd(i64 x,i64 y)
{
    if(y==0) return x;
    return Gcd(y,x%y);
}

int main()
{
    RD(n,m);
    build(1,1,n-1);
    int L,R;
    i64 x,ans,S,k;
    char op[5];
    while(m--)
    {
        RD(op);
        if(op[0]=='C') 
        {
            RD(L,R); R--;
            RD(x);
            update(1,L,R,x);
        }
        else 
        {
            RD(L,R); R--;
            ans=getSum(1,L,R).S;
            S=get1(R-L+1);
            k=Gcd(ans,S);
            ans/=k; S/=k;
            printf("%lld/%lld\n",ans,S);
        }
    }
}

BZOJ 2752 高速公路(road)(线段树)的更多相关文章

  1. Bzoj 2752 高速公路 (期望,线段树)

    Bzoj 2752 高速公路 (期望,线段树) 题目链接 这道题显然求边,因为题目是一条链,所以直接采用把边编上号.看成序列即可 \(1\)与\(2\)号点的边连得是. 编号为\(1\)的点.查询的时 ...

  2. BZOJ 2752: [HAOI2012]高速公路(road)( 线段树 )

    对于询问[L, R], 我们直接考虑每个p(L≤p≤R)的贡献,可以得到 然后化简一下得到 这样就可以很方便地用线段树, 维护一个p, p*vp, p*(p+1)*vp就可以了 ----------- ...

  3. BZOJ 2752: [HAOI2012]高速公路(road) [线段树 期望]

    2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1219  Solved: 446[Submit] ...

  4. BZOJ2752: [HAOI2012]高速公路(road)(线段树 期望)

    Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1820  Solved: 736[Submit][Status][Discuss] Descripti ...

  5. 【bzoj2752】[HAOI2012]高速公路(road) 线段树

    题目描述 Y901高速公路是一条重要的交通纽带,政府部门建设初期的投入以及使用期间的养护费用都不低,因此政府在这条高速公路上设立了许多收费站.Y901高速公路是一条由N-1段路以及N个收费站组成的东西 ...

  6. [bzoj2752]高速公路 题解(线段树)

    2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 2102  Solved: 887[Submit] ...

  7. [BZOJ 2752] 高速公路

    Link: BZOJ 2752 传送门 Solution: 虽然有期望,但实际上就是除了个总数…… 此题计算总代价明显还是要使用对每个$w_i$计算贡献的方式: $w_i的贡献为w_i*(i-l+1) ...

  8. BZOJ.3938.Robot(李超线段树)

    BZOJ UOJ 以时间\(t\)为横坐标,位置\(p\)为纵坐标建坐标系,那每个机器人就是一条\(0\sim INF\)的折线. 用李超线段树维护最大最小值.对于折线分成若干条线段依次插入即可. 最 ...

  9. BZOJ.1558.[JSOI2009]等差数列(线段树 差分)

    BZOJ 洛谷 首先可以把原序列\(A_i\)转化成差分序列\(B_i\)去做. 这样对于区间加一个等差数列\((l,r,a_0,d)\),就可以转化为\(B_{l-1}\)+=\(a_0\),\(B ...

随机推荐

  1. if-else的优化举例

    共有部分: String bookFrom = null; String sheetFrom = null; String bookTo = null; String sheetTo = null; ...

  2. 先进的自动布局工具箱(autolayout)

    原文:Advanced Auto Layout Toolbox 这篇文章并没有具体介绍自动布局的一些基本概念,主要讲解了一些高级的使用方法和调试技巧,文中有的句子比较长,意思也有点难懂,所以需要静下心 ...

  3. ios读取通讯录信息

    ios读取通讯录信息 (2012-05-22 14:07:11) 标签: ios读取通讯录 it   iphone如许app读取通讯录信息,读取通讯录信息时需要加载AddressBookUI 和Add ...

  4. centos6.5安装图形界面,windows远程linux图形界面

    1. 查询是否已安装图形界面 yum grouplist |more 在grouplist的输出结果中的“Installed Groups:”部分中,如果你能找到“X Window System”和G ...

  5. Centos编译安装PHP 5.5笔记

    本篇是在 Centos 6.4 32bit 下编译安装 php 5.5.5 的笔记,接上篇 Centos编译安装Apache 2.4.6笔记.php 5.5.x 和 centos 源里面的 php 5 ...

  6. Metasploit Framework命令汇总

    一.msfconsole ? 帮助菜单back 从当前环境返回banner 显示一个MSF bannercd 切换目录color 颜色转换connect 连接一个主机exit 退出MSFhelp 帮助 ...

  7. ACM入门记

    [2015.12]零基础进队 [2016.4.10]浙大第十六届程序设计大赛 [2016.6.4]团体程序设计天梯赛初赛 [2016.7.16]团体程序设计天梯赛决赛 赛后总结:比赛的时候好慌,一道题 ...

  8. 较复杂js的书写格式

    我们看较复杂的js程序最怕结构混乱,一个好的js书写结构,在很大程度上可以减缓阅读的障碍性. 我感觉一个良好的结构要有两点:一是要有一个统一的入口,这样就保证了程序的可阅读性:二是要能够灵活的设置参数 ...

  9. 两台机器间libevent通信:No route to host问题

    最近学习libevent库,遂在两台虚拟机间模拟通信,程序没逻辑错误,但客户端总是提示No route to host问题,想到可能是linux的防火墙问题导致的,于是关掉防火墙: Ubuntu系统防 ...

  10. 用HAProxy和KeepAlived构建高可用的反向代理

      用HAProxy和KeepAlived构建高可用的反向代理 用HAProxy和KeepAlived构建高可用的反向代理 前言对于访问量较大的网站来说,随着流量的增加单台服务器已经无法处理所有的请求 ...