http://www.lydsy.com/JudgeOnline/problem.php?id=2752

https://www.luogu.org/problemnew/show/P2221#sub

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将期望花费多少费用呢?

洛谷给它定的标签是“概率期望”,实际上难在维护线段树。

首先我们把路费变成点费,那么n--,所有询问r--。

那么期望=(所有路段的钱的和)/(路段个数),路段个数很好求,专注维护前面的。

对于一个数v[i],它所提供的价值为:

(1+r-l-lr)*v[i]+(l+r)*i*v[i]-i*i*v[i]。

所以维护v[i],i*v[i],i*i*v[i]即可。

#include<cstdio>
#include<cmath>
#include<iostream>
#include<vector>
#include<cstring>
#include<algorithm>
#include<cctype>
using namespace std;
typedef long long ll;
const int N=;
inline int read(){
int X=,w=;char ch=;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch))X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
inline char getc(){
char ch=getchar();
while(ch<'A'||ch>'Z')ch=getchar();
return ch;
}
inline ll sig(ll l,ll r){
return (l+r)*(r-l+)>>;
}
inline ll ssig(ll l,ll r){
ll a=(l-)*l*(*l-)/;
ll b=r*(r+)*(*r+)/;
return b-a;
}
ll tr[N][],lazy[N];
void push(int a,int l,int r,int mid){
if(!lazy[a])return;
tr[a<<][]+=(mid-l+)*lazy[a];
tr[a<<|][]+=(r-mid)*lazy[a];
tr[a<<][]+=sig(l,mid)*lazy[a];
tr[a<<|][]+=sig(mid+,r)*lazy[a];
tr[a<<][]+=ssig(l,mid)*lazy[a];
tr[a<<|][]+=ssig(mid+,r)*lazy[a];
lazy[a<<]+=lazy[a];
lazy[a<<|]+=lazy[a];
lazy[a]=;
}
void modify(int a,ll l,ll r,ll l1,ll r1,ll v){
if(r<l1||r1<l)return;
if(l1<=l&&r<=r1){
lazy[a]+=v;
tr[a][]+=(r-l+)*v;
tr[a][]+=sig(l,r)*v;
tr[a][]+=ssig(l,r)*v;
return;
}
ll mid=(l+r)>>;
push(a,l,r,mid);
modify(a<<,l,mid,l1,r1,v);modify(a<<|,mid+,r,l1,r1,v);
tr[a][]=tr[a<<][]+tr[a<<|][];
tr[a][]=tr[a<<][]+tr[a<<|][];
tr[a][]=tr[a<<][]+tr[a<<|][];
}
ll query(int a,ll l,ll r,ll l1,ll r1){
if(r<l1||r1<l)return ;
if(l1<=l&&r<=r1){
return (+r1-l1-l1*r1)*tr[a][]+(l1+r1)*tr[a][]-tr[a][];
}
ll mid=(l+r)>>;
push(a,l,r,mid);
return query(a<<,l,mid,l1,r1)+query(a<<|,mid+,r,l1,r1);
}
ll gcd(ll a,ll b){
return (!b)?a:gcd(b,a%b);
}
int main(){
int n=read()-,m=read();
for(int i=;i<=m;i++){
char ch=getc();
int l=read(),r=read()-;
if(ch=='C')modify(,,n,l,r,read());
else{
ll a=query(,,n,l,r),b=sig(,r-l+);
ll g=gcd(a,b);
printf("%lld/%lld\n",a/g,b/g);
}
}
return ;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

BZOJ2752:[HAOI2012]高速公路——题解的更多相关文章

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

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

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

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

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

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

  4. [BZOJ2752][HAOI2012]高速公路

    BZOJ Luogu sol 看上去是道数学期望题但实际上是个傻逼数据结构 首先答案的形式应该就是 \[\frac{\mbox{[l,r]区间内的子区间权值之和}}{\mbox{[l,r]区间内的子区 ...

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

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

  6. luogu P2221 [HAOI2012]高速公路题解

    题面 很套路的拆式子然后线段树上维护区间和的题.一般都是把式子拆成区间内几个形如\(\sum i*a_i, \sum i^2 * a_i\)的式子相加减的形式. 考虑一次询问[l,r]的答案怎么算: ...

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

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

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

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

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

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

随机推荐

  1. 阿里otter使用问题汇总

    最近在使用otter做为和表从库.(100个分表太难查询了) user_00,user_01...user_99 => user_all 1.问题DDL语句不能执行(exception:setl ...

  2. Android事件分发机制浅析(1)

    本文来自网易云社区 作者:孙有军 事件机制是Android中一个比较复杂且重要的知识点,比如你想自定义拦截事件,或者某系组件中嵌套了其他布局,往往会出现这样那样的事件冲突,坑爹啊!!事件主要涵盖onT ...

  3. 打造移动应用与游戏安全防线,腾讯WeTest安全服务全线升级

    当移动互联网渗透到千家万户,与工业控制.智慧交通.实时社交.休闲娱乐紧密结合时,应用安全就变得尤为重要. 尤其在网络强相关的APP流行年代,当APP应用客户端上传与获取信息,大多通过接口在服务器双向通 ...

  4. eclipse注释快捷键

    1.单行注释 注释: ctrl + / 取消注释: ctrl + / 多行注释 注释: ctrl shift + / 取消注释: ctrl shift + \

  5. 解决jQuery不同版同时引用的冲突

    今天研发的同事在开发一个新jQuery插件时,遇到一个揪心的问题.平台以前使用的 jQuery版本是1.2.6,偶,天啊!这是古代的版本啊! 由于很多功能基于老版本,不能删除啊,同志们都懂的! 于是我 ...

  6. 论文笔记:Attentional Correlation Filter Network for Adaptive Visual Tracking

    Attentional Correlation Filter Network for Adaptive Visual Tracking CVPR2017 摘要:本文提出一种新的带有注意机制的跟踪框架, ...

  7. sql随机数

    ) as P_jsnews_id ) as P_jsnews_id) * from P_jsnews order by newid()

  8. SpringBoot日志配置(详解) 涉及控制台输出日志、生成日志文件、日志级别修改、hibernate日志不输出

    写在前面 本篇主要讲述日志配置,看完本篇可以解决下述问题, 控制台输出日志.生成日志文件.日志级别修改.hibernate日志不输出 Git Demo Path:https://github.com/ ...

  9. POJ 1655 Balancing Act(求树的重心)

    Description Consider a tree T with N (1 <= N <= 20,000) nodes numbered 1...N. Deleting any nod ...

  10. H5页面 绝对定位元素被 软键盘弹出时顶起

    H5页面 绝对定位元素被 软键盘弹出时顶起 在h5页面开发的过程中,我们可能会遇到下面这个问题,当页面中有输入框的时候,系统自带的软盘会把按钮挤出原来的位置.那么我们该怎么解决呢?下面列出一下的方法: ...