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. 新版本Eclipse安装后插件都在哪里?

    201903版本的Eclipse,选择win安装,下载后的安装包大小只有48.7Mb, 双击安装会会弹出类似eclipse网页,选择需要安装的类型,一般选择Java EE版本 选择好版本后,选择安装目 ...

  2. Unity Container中的几种注册方式与示例

    1.实例注册 最简单的注册方式就是实例注册,Unity 容器负责维护对一个类型的单例引用,比如: 有如下的实际类型: namespace ConsoleSample { public class Sa ...

  3. 程序员的冷笑话 python版本

    在伯乐在线上看到了个冷笑话,感觉很有意思. void tellStory() { printf("从前有座山\n"); printf("山上有座庙\n"); p ...

  4. Postman 高级用法指南

    Postman是一款强大的API接口测试工具,有许多不容易发现的好用的功能,下面简单介绍其中一部分功能.详细内容可以参考文档,官方还有视频教程,非常方便入手.后续本博客会持续提供一些Postman使用 ...

  5. Unity编辑器 - 资源修改立即写入磁盘AssetDataBase.SaveAssets()

    Unity编辑器 - 资源修改立即写入磁盘AssetDataBase.SaveAssets() 在编写编辑器时,如果需要修改Unity序列化资源(如Prefab,美术资源,ScriptableObje ...

  6. 关于axios跨域带cookie

    axios  设置 withCredentials :true $u = $_SERVER['HTTP_REFERER'];$u = preg_replace('#/$#', '', $u);head ...

  7. [Clr via C#读书笔记]Cp15枚举和位标识

    Cp15枚举和位标识 枚举类型 本质是结构,符号名称-值:好处显而易见:System.Enum;值类型: 编译的时候,符号会转换为常量字段: 枚举支持很多方法和成员: 位标识bit flag 判断和设 ...

  8. Python3 数据类型-字典

    字典是一种可变数据类型,且可存储任意类型对象. 字典使用大括号"{}"括起来,由键(key)和值(values)组成,键只能使用不可变类型定义,值可以使用可变类型{'键':'值'} ...

  9. Icingaweb2监控oracle数据库的安装配置流程

    Icinga2安装配置check_oracle_health流程 1.安装 由于check_oracle_health是使用perl语言编写的,因此在安装该插件之前,首先要安装oracle的客户端实例 ...

  10. JavaScript筑基篇(二)->JavaScript数据类型

    说明 介绍JavaScript数据类型 目录 前言 参考来源 前置技术要求 JavaScript的6种数据类型 哪6种数据类型 undefined 类型 null 类型 boolean 类型 numb ...