高速公路 [HAOI2012] [线段树]
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] [线段树]的更多相关文章
- Bzoj 2752 高速公路 (期望,线段树)
Bzoj 2752 高速公路 (期望,线段树) 题目链接 这道题显然求边,因为题目是一条链,所以直接采用把边编上号.看成序列即可 \(1\)与\(2\)号点的边连得是. 编号为\(1\)的点.查询的时 ...
- BZOJ 2752: [HAOI2012]高速公路(road)( 线段树 )
对于询问[L, R], 我们直接考虑每个p(L≤p≤R)的贡献,可以得到 然后化简一下得到 这样就可以很方便地用线段树, 维护一个p, p*vp, p*(p+1)*vp就可以了 ----------- ...
- BZOJ 2752: [HAOI2012]高速公路(road) [线段树 期望]
2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1219 Solved: 446[Submit] ...
- P2221 [HAOI2012]高速公路(线段树)
P2221 [HAOI2012]高速公路 显然答案为 $\dfrac{\sum_{i=l}^r\sum_{j=l}^{r}dis[i][j]}{C_{r-l+1}^2}$ 下面倒是挺好算,组合数瞎搞 ...
- BZOJ2752: [HAOI2012]高速公路(road)(线段树 期望)
Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1820 Solved: 736[Submit][Status][Discuss] Descripti ...
- 【bzoj2752】[HAOI2012]高速公路(road) 线段树
题目描述 Y901高速公路是一条重要的交通纽带,政府部门建设初期的投入以及使用期间的养护费用都不低,因此政府在这条高速公路上设立了许多收费站.Y901高速公路是一条由N-1段路以及N个收费站组成的东西 ...
- 2019.01.14 bzoj2752: [HAOI2012]高速公路(线段树)
传送门 线段树菜题. 题意简述:给一条nnn个点的链,链有边权,支持区间修改边权,查询在一段区间内随机选择不同的起点和终点路径的期望总边权和. 思路:考虑每条边的贡献. 考虑对于一段区间[l,r][l ...
- 洛谷P2221 [HAOI2012]高速公路(线段树+概率期望)
传送门 首先,答案等于$$ans=\sum_{i=l}^r\sum_{j=i}^r\frac{sum(i,j)}{C_{r-l+1}^2}$$ 也就是说所有情况的和除以总的情况数 因为这是一条链,我们 ...
- [bzoj2752]高速公路 题解(线段树)
2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 2102 Solved: 887[Submit] ...
随机推荐
- Ueditor设置默认字体、字号、行间距,添加字体种类(转)
Ueditor默认字体.字号.行间距的修改: ueditor默认字号是16号,默认字体为sans-serif,默认行间距为5px,如下图所示: 首先,修改ueditor.all.js文件中如上图红框中 ...
- Windows系统下安装运行Kafka
一.安装JAVA JDK 1.下载安装包 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151. ...
- oracle创建用户和密码以及授权登录问题
创建有户名和密码CREATE USER 用户名 IDENTIFIED BY 密码;分配权限GRANT connect,dba to 用户名; 1:使用oracle的命令行登录oracle的方式(安装好 ...
- NetCore 生成RSA公私钥对,公钥加密私钥解密,私钥加密公钥解密
using Newtonsoft.Json; using Org.BouncyCastle.Crypto; using Org.BouncyCastle.Crypto.Encodings; using ...
- mysql的下载与安装
官网 下载 https://www.mysql.com/ 依次点击:downloads>community>mysql community server,如图所示 image.png ...
- Java基础知识➣发送Emai和访问MySQL数据库(七)
概述 Java程序发送 E-mail 十分简单,但是首先你应该在你的机器上安装 JavaMail API 和Java Activation Framework (JAF) .Java访问数据则需要 使 ...
- Python_copy_深浅拷贝
对于数字和字符串来说,无论是‘’赋值‘’还是‘’深拷贝‘’还是‘’浅拷贝‘’都是指向的同一个地址 深浅拷贝是copy类下的方法,创建方式为 import copy copy.copy() #浅拷贝 c ...
- net core体系-web应用程序-2项目简单案例
阅读目录 NO1 留言板(mysql的使用) NO2 聊天室(WebSocket的使用) NO3 找工作(AngleSharp的使用) 部署多个站点 一些其它的细节 部署阿里云 mysql的客户端 ...
- Python学习(十一) —— 模块和包
一.模块 一个模块就是一个包含了python定义和声名的文件,文件名就是模块名加上.py后缀. import加载的模块分为四个通用类别: 1.使用python编写的代码(.py文件) 2.已被编译为共 ...
- POJ 3579 Median 【二分答案】
<题目链接> 题目大意: 给出 N个数,对于存有每两个数的差值的序列求中位数,如果这个序列长度为偶数个元素,就取中间偏小的作为中位数. 解题分析: 由于本题n达到了1e5,所以将这些数之间 ...