数学期望/线段树


  然而又是一道road= =上一道是2750……

  下次不要一看期望题就弃疗么……

  期望题≠不可做题……!!

  其实在这题中,期望就是(所有情况下 权值之和)/(总方案数)

  因为是等概率抽取区间啊= =2333

  然而分母很好搞,直接就能算出来,所以我们要来搞分子……

  分子其实是个这玩意:$$\sum_{i=l}^{r} v[i]*(i-l+1)*(r-i+1)$$
  (我不会告诉你一开始我没加“+1”……)

  然而我一开始直接用“几何意义”之类的鬼玩意想往上套,果断跪了Orz

  膜拜了zyf的题解,其实正确姿势是这样的!$$\begin{aligned} \sum_{i=l}^{r} v[i]*(i-l+1)*(r-i+1) &= \sum_{i=l}^{r} v[i]*[(r-l-l*r+1)+i*(l+r)-i^2] \\ &=\sum_{i=l}^{r} \big (v[i]*(r-l-l*r+1) + v[i]*i*(l+r)-v[i]*i^2 \big ) \end{aligned}$$

  然后知道了这个能干嘛?…………其实………… l 和 r 就是询问的 l 和 r ,所以我们只需要维护与 i 相关的项,即$\sum v[i]$、$\sum v[i]*i$和$\sum v[i]*i^2$就可以计算答案啦~(然而蒟蒻没想到……T^T

  嗯……怎么维护?合并就是直接加嘛= =反正只跟坐标相关,然后对整个区间都add一个值?……这是数学问题不要问我>_>  (其实我也不会

WA:在upd的时候,由于运算时出现了l*r这个不和谐的项……所以传进去的 l 和 r 得是long long

 /**************************************************************
Problem: 2752
User: Tunix
Language: C++
Result: Accepted
Time:3712 ms
Memory:16904 kb
****************************************************************/ //BZOJ 2752
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
#define pb push_back
using namespace std;
typedef long long LL;
inline LL getint(){
LL r=,v=; char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if (ch=='-') r=-;
for(; isdigit(ch);ch=getchar()) v=v*-''+ch;
return r*v;
}
const int N=;
/*******************template********************/
int n,m;
struct node{
LL num[],ad;
node(){F(i,,) num[i]=; ad=;}
}t[N<<]; node maintain(node L,node R){
node tmp;
F(i,,) tmp.num[i]=L.num[i]+R.num[i];
return tmp;
}
#define mid (l+r>>1)
#define L (o<<1)
#define R (o<<1|1)
void upd(int o,LL l,LL r,LL v){
t[o].ad+=v;
t[o].num[]+=v*(r-l+);
t[o].num[]+=v*(r+l)*(r-l+)/;
t[o].num[]+=v*(r*(r+)*(*r+)-(l-)*l*(*l-))/;//数学没学好QAQ
}
void Push_down(int o,int l,int r){
if (t[o].ad){
upd(L,l,mid,t[o].ad);
upd(R,mid+,r,t[o].ad);
t[o].ad=;
}
}
void update(int o,int l,int r,int ql,int qr,LL v){
if (ql<=l && qr>=r) upd(o,l,r,v);
else{
Push_down(o,l,r);
if (ql<=mid) update(L,l,mid,ql,qr,v);
if (qr>mid) update(R,mid+,r,ql,qr,v);
t[o]=maintain(t[L],t[R]);
}
}
node query(int o,int l,int r,int ql,int qr){
if (ql<=l && qr>=r) return t[o];
else{
Push_down(o,l,r);
node ans;
if (ql<=mid) ans=maintain(ans,query(L,l,mid,ql,qr));
if (qr>mid) ans=maintain(ans,query(R,mid+,r,ql,qr));
return ans;
}
}
inline LL gcd(LL a,LL b){return b ? gcd(b,a%b) : a;}
void solve(LL fz,LL fm){
fm=fm*(fm+)/;
LL d=gcd(abs(fz),fm);
// cout << fz <<" "<<fm<<' '<<d<<endl;
fz/=d; fm/=d;
printf("%lld/%lld\n",fz,fm);
}
int main(){
#ifndef ONLINE_JUDGE
freopen("2752.in","r",stdin);
freopen("2752.out","w",stdout);
#endif
n=getint()-; m=getint();
char cmd[];
F(i,,m){
scanf("%s",cmd);
LL l=getint(),r=getint()-,v;
if (cmd[]=='C'){
v=getint();
update(,,n,l,r,v);
}else{
node ans=query(,,n,l,r);
LL fz=ans.num[]*(r-l-l*r+)+ans.num[]*(l+r)-ans.num[];
solve(fz,r-l+);
}
}
return ;
}

2752: [HAOI2012]高速公路(road)

Time Limit: 20 Sec  Memory Limit: 128 MB
Submit: 807  Solved: 287
[Submit][Status][Discuss]

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<r<=N

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的非负整数

所有测试点的详细情况如下表所示

Test N M

1 =10 =10

2 =100 =100

3 =1000 =1000

4 =10000 =10000

5 =50000 =50000

6 =60000 =60000

7 =70000 =70000

8 =80000 =80000

9 =90000 =90000

10 =100000 =100000

Source

[Submit][Status][Discuss]

【BZOJ】【2752】【HAOI2012】高速公路(Road)的更多相关文章

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

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

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

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

  3. bzoj 2752: [HAOI2012]高速公路(road)

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

  4. ●BZOJ 2752 [HAOI2012]高速公路(road)

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2752题解: 期望,线段树. 把每个路段看成一个点,那么对于l~R的操作,就可以转化为对l~r ...

  5. BZOJ 2752 [HAOI2012]高速公路(road):线段树【维护区间内子串和】

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2752 题意: 有一个初始全为0的,长度为n的序列a. 有两种操作: (1)C l r v: ...

  6. BZOJ2752: [HAOI2012]高速公路(road)

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

  7. 【线段树】BZOJ2752: [HAOI2012]高速公路(road)

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

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

    [HAOI2012]高速公路(road) Description Y901高速公路是一条重要的交通纽带,政府部门建设初期的投入以及使用期间的养护费用都不低,因此政府在这条高速公路上设立了许多收费站.Y ...

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

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

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

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

随机推荐

  1. Ionic Js三:下拉刷新

    在加载新数据的时候,我们需要实现下拉刷新效果,代码如下: HTML 代码 <body ng-app="starter" ng-controller="actions ...

  2. 排序算法之直接插入排序Java实现

    排序算法之直接插入排序 舞蹈演示排序: 冒泡排序: http://t.cn/hrf58M 希尔排序:http://t.cn/hrosvb  选择排序:http://t.cn/hros6e  插入排序: ...

  3. POJ 3177 Redundant Paths 双联通分量 割边

    http://poj.org/problem?id=3177 这个妹妹我大概也曾见过的~~~我似乎还没写过双联通分量的blog,真是智障. 最少需要添多少条边才能使这个图没有割边. 边双缩点后图变成一 ...

  4. [COGS2580]偏序 II

    [COGS2580]偏序 II 题目大意: \(n(n\le50000)\)个五元组,求五维偏序. 思路: CDQ分治套CDQ分治套CDQ分治套树状数组. 时间复杂度\(\mathcal O(n\lo ...

  5. 【BZOJ】4152: [AMPPZ2014]The Captain【SLF优化Spfa】

    4152: [AMPPZ2014]The Captain Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 2107  Solved: 820[Submi ...

  6. XMOJ 1133: 膜拜大牛 计算几何/两圆相交

    1133: 膜拜大牛 Time Limit: 1 Sec  Memory Limit: 131072KiBSubmit: 9619  Solved: 3287 题目连接 http://acm.xmu. ...

  7. hdoj 4450 Draw Something 水题

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

  8. Android 性能监控系列一(原理篇)

    欢迎关注微信公众号:BaronTalk,获取更多精彩好文! 一. 前言 性能问题是导致 App 用户流失的罪魁祸首之一,如果用户在使用我们 App 的时候遇到诸如页面卡顿.响应速度慢.发热严重.流量电 ...

  9. LAMP架构之NFS

    需求分析: 前端需支持更大的访问量,单台Web服务器已无法满足需求了,则需扩容Web服务器: 虽然动态内容可交由后端的PHP服务器执行,但静态页面还需要Web服务器自己解析,那是否意味着多台Web服务 ...

  10. linux 定时任务 crontab 详细解释(转)

    cron 是linux的内置服务,但它不自动起来,可以用以下的方法启动.关闭这个服务:  引用:  /sbin/service crond start //启动服务  /sbin/service cr ...