Description

Y901高速公路是一条重要的交通纽带,政府部门建设初期的投入以及使用期间的养护费用都不低,因此政府在这条高速公路上设立了许多收费站。
Y901高速公路是一条由N-1段路以及N个收费站组成的东西向的链,我们按照由西向东的顺序将收费站依次编号为1~N,从收费站i行驶到i+1(或从i+1行驶到i)需要收取Vi的费用。高速路刚建成时所有的路段都是免费的。
政府部门根据实际情况,会不定期地对连续路段的收费标准进行调整,根据政策涨价或降价。
无聊的小A同学总喜欢研究一些稀奇古怪的问题,他开车在这条高速路上行驶时想到了这样一个问题:对于给定的l,r(l<r),在第l个到第r个收费站里等概率随机取出两个不同的收费站a和b,那么从a行驶到b将期望花费多少费用呢?

Input

第一行2个正整数N,M,表示有N个收费站,M次调整或询问
接下来M行,每行将出现以下两种形式中的一种
C l r v 表示将第l个收费站到第r个收费站之间的所有道路的通行费全部增加v
Q l r 表示对于给定的l,r,要求回答小A的问题
所有C与Q操作中保证1<=l l<r,在第l个到第r个收费站里等概率随机取出两个不同的收费站a和b,那么从a行驶到b将期望花费多少费用呢?

Output

对于每次询问操作回答一行,输出一个既约分数
若答案为整数a,输出a/1

Sample Input

4 5
C 1 4 2
C 1 2 -1
Q 1 2
Q 2 4
Q 1 4

Sample Output

1/1
8/3
17/6

Hint

数据约束

所有C操作中的v的绝对值不超过10000

在任何时刻任意道路的费用均为不超过10000的非负整数

N,M<=1e5

Solution
对于一次询问,第i条边的贡献为 wi*(i-L+1)*(R-i+1)

可以这么理解,在i的左边(包括自身)选择起点,在i的右边(包括自身)选择终点,相乘即为组合的个数

然后

我们就可以看出,用线段树分别维护三个值:S0:∑wi , S1:∑(wi*i) , S2:∑(wi*i2)即可

(S2漏乘了一个val)

这个该死的线段树调了我两个小时。以后打线段树还是要小心一点慢点打 = =

Code

 #include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define RG register int
#define rep(i,a,b) for(RG i=a;i<=b;i++)
#define per(i,a,b) for(RG i=a;i>=b;i--)
#define inf (1<<30)
#define maxn 100005
#define ll long long
#define ls pos<<1
#define rs pos<<1|1
#define L t[pos].l
#define R t[pos].r
#define mid ((t[pos].l+t[pos].r)>>1)
#define cal0(x,y) x*y
#define cal1(x,y,z,w) (x+y)*z*w/2ll
#define cal2(x,y,z) (y*(y+1ll)*(2ll*y+1ll)-x*(x-1ll)*(2ll*x-1ll))*z/6ll //bug
using namespace std;
int n,m;
struct T{
int l,r;
ll s0,s1,s2,tag;
}t[maxn<<];
struct Dat{
ll a0,a1,a2;
inline Dat operator + (const Dat x)const{
return (Dat){a0+x.a0,a1+x.a1,a2+x.a2};
}
};
inline int read()
{
int x=,f=;char c=getchar();
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} void build(int pos,int l,int r)
{
t[pos].l=l,t[pos].r=r;
if(l==r) return;
build(ls,l,mid);build(rs,mid+,r);
} inline void pushdown(int pos)
{
t[ls].tag+=t[pos].tag,t[rs].tag+=t[pos].tag;
ll len1=t[ls].r-t[ls].l+,len2=t[rs].r-t[rs].l+;//bug t[ls].s0+=cal0(len1,t[pos].tag),
t[ls].s1+=cal1(t[ls].l,t[ls].r,len1,t[pos].tag),
t[ls].s2+=cal2(t[ls].l,t[ls].r,t[pos].tag); t[rs].s0+=cal0(len2,t[pos].tag),
t[rs].s1+=cal1(t[rs].l,t[rs].r,len2,t[pos].tag),
t[rs].s2+=cal2(t[rs].l,t[rs].r,t[pos].tag); t[pos].tag=;
} void update(int pos,int l,int r,ll val)
{
if(l<=L&&R<=r)
{
ll len=R-L+;
t[pos].s0+=cal0(len,val),
t[pos].s1+=cal1(L,R,len,val),
t[pos].s2+=cal2(L,R,val);
t[pos].tag+=val;
return;
}
if(t[pos].tag) pushdown(pos);
if(l<=mid) update(ls,l,r,val);//bug
if(r>mid) update(rs,l,r,val);//bug
t[pos].s0=t[ls].s0+t[rs].s0,
t[pos].s1=t[ls].s1+t[rs].s1,
t[pos].s2=t[ls].s2+t[rs].s2;
} Dat query(int pos,int l,int r)
{
if(l<=t[pos].l&&t[pos].r<=r)
return (Dat){t[pos].s0,t[pos].s1,t[pos].s2};
if(t[pos].tag) pushdown(pos);
Dat ans=(Dat){,,};
if(l<=mid) ans=query(ls,l,r);
if(r>mid) ans=ans+query(rs,l,r);
return ans;
} ll gcd(ll a,ll b){return (!(a%b)?b:gcd(b,a%b));} int main()
{
n=read(),m=read();
build(,,n-);
char opt[];
register ll l,r,v;
rep(i,,m)
{
scanf("%s",opt);
if(opt[]=='C')
{
l=read(),r=read()-,v=read();
update(,l,r,v);
}
else
{
l=read(),r=read()-;
Dat ans=query(,l,r);
ll up=ans.a0*(r-l-l*r+1ll)+ans.a1*(l+r)-ans.a2;
ll down=(r-l+1ll)*(r-l+2ll)/2ll;
ll gd=gcd(up,down);
up/=gd,down/=gd;
printf("%lld/%lld\n",up,down);
}
}
return ;
}

高速公路 [HAOI2012] [线段树]的更多相关文章

  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. P2221 [HAOI2012]高速公路(线段树)

    P2221 [HAOI2012]高速公路 显然答案为 $\dfrac{\sum_{i=l}^r\sum_{j=l}^{r}dis[i][j]}{C_{r-l+1}^2}$ 下面倒是挺好算,组合数瞎搞 ...

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

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

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

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

  7. 2019.01.14 bzoj2752: [HAOI2012]高速公路(线段树)

    传送门 线段树菜题. 题意简述:给一条nnn个点的链,链有边权,支持区间修改边权,查询在一段区间内随机选择不同的起点和终点路径的期望总边权和. 思路:考虑每条边的贡献. 考虑对于一段区间[l,r][l ...

  8. 洛谷P2221 [HAOI2012]高速公路(线段树+概率期望)

    传送门 首先,答案等于$$ans=\sum_{i=l}^r\sum_{j=i}^r\frac{sum(i,j)}{C_{r-l+1}^2}$$ 也就是说所有情况的和除以总的情况数 因为这是一条链,我们 ...

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

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

随机推荐

  1. springboot的创建

  2. python 内建函数

    # # __geratteibute__class Itcast(object): def __init__(self,subject1): self.subject1 = subject1 self ...

  3. 让simplejson支持datetime类型的序列化

    simplejson是Python的一个json包,但是觉得有点不爽,就是不能序列化datetime,稍作修改就可以了: 原文:http://blog.csdn.net/hong201/article ...

  4. Android实时取景:用SurfaceView实现

    对于基于摄像头的Android应用,实时取景是一个基本前提,通过前置或后置摄像头持续获取捕获到的内容,可以进一步做处理(人脸检测.美颜.滤镜等). 所谓实时取景,简单说就是调用android的摄像头, ...

  5. 647. Palindromic Substrings

    Given a string, your task is to count how many palindromic substrings in this string. The substrings ...

  6. LVS(IPVS)了解

    从来都只是看文章,现在手工作一下. 参考URL: https://blog.csdn.net/langyue919/article/details/80935197 https://www.cnblo ...

  7. HDU 1074 Doing Homework(DP状态压缩)

    题意:有n门功课需要完成,每一门功课都有时间期限以及你完成所需要的时间,如果完成的时间超出时间期限多少单位,就会被减多少学分,问以怎样的功课完成顺序,会使减掉的学分最少,有多个解时,输出功课名字典序最 ...

  8. php让一个数组按照另外一个数组的键名进行排序

    $a = [ 'id', 'name', 'identityId', 'phone', 'email', 'schoolId' ]; $b = [ 'id' => '唯一标识', 'identi ...

  9. Chino的数列

    题解: 一道练代码能力的题目.. 首先很显然他是一道平衡树裸题 第5个操作是势能分析维护最大值最小值就可以了 另外设置虚点和noip2017队列那题一样(不过我只写过线段树) 具体细节: 1.内存池, ...

  10. .Net core2.0+Mysql5.7部署到CentOS7.5完整实践经验

    本文为本人最近学习将.Net Core部署到Linux的一些经验总结,也提供点也和我一样对Linux接触不多的.Net Core开发者. 一.部署用到的环境和工具 1.Linux采用最新的CentOS ...