[luoguP2221] [HAOI2012]高速公路(线段树)
考虑每一段对答案的贡献
用每一段的左端点来表示当前这一段,那么区间就变成了[1,n-1]
如果询问区间[l,r],其中一个点的位置为x,则它对答案的贡献为(x-l)*(r-x)*s[x](s[x]为这一段的权值)
化简后得x*s[x]*(l+r-1)-s[x]*(l*r-r)-x*x*s[x]
那么我们就需要维护x*s[x],s[x],x*x*s[x]
其中还需要预处理出来x和x*x
然后就ok了
#include <cstdio>
#include <cstring>
#include <iostream>
#define N 500001
#define LL long long
#define root 1, 1, n - 1
#define ls now << 1, l, mid
#define rs now << 1 | 1, mid + 1, r using namespace std; int n, m;
LL s, xs, xxs, ans1, ans2;
LL x1[N], x2[N], sum1[N], sum2[N], sum3[N], add[N];
//x1表示 x
//x2表示 x^2
//sum1表示 s[x]
//sum2表示 x * s[x]
//sum3表示 x^2 * s[x] inline int read()
{
int x = 0, f = 1;
char ch = getchar();
for(; !isdigit(ch); ch = getchar()) if(ch == '-') f = -1;
for(; isdigit(ch); ch = getchar()) x = (x << 1) + (x << 3) + ch - '0';
return x * f;
} inline void push_down(int now, int l, int r)
{
if(add[now])
{
int mid = (l + r) >> 1;
sum1[now << 1] += 1ll * add[now] * (mid - l + 1);
sum1[now << 1 | 1] += 1ll * add[now] * (r - mid);
sum2[now << 1] += add[now] * x1[now << 1];
sum2[now << 1 | 1] += add[now] * x1[now << 1 | 1];
sum3[now << 1] += add[now] * x2[now << 1];
sum3[now << 1 | 1] += add[now] * x2[now << 1 | 1];
add[now << 1] += add[now];
add[now << 1 | 1] += add[now];
add[now] = 0;
}
} inline void push_up(int now)
{
sum1[now] = sum1[now << 1] + sum1[now << 1 | 1];
sum2[now] = sum2[now << 1] + sum2[now << 1 | 1];
sum3[now] = sum3[now << 1] + sum3[now << 1 | 1];
} inline void update(int now, int l, int r, int x, int y, LL z)
{
if(x <= l && r <= y)
{
add[now] += z;
sum1[now] += 1ll * z * (r - l + 1);
sum2[now] += 1ll * z * x1[now];
sum3[now] += 1ll * z * x2[now];
return;
}
push_down(now, l, r);
int mid = (l + r) >> 1;
if(x <= mid) update(ls, x, y, z);
if(mid < y) update(rs, x, y, z);
push_up(now);
} inline void build(int now, int l, int r)
{
if(l == r)
{
x1[now] += l;
x2[now] += 1ll * l * l;
return;
}
int mid = (l + r) >> 1;
build(ls);
build(rs);
x1[now] = x1[now << 1] + x1[now << 1 | 1];
x2[now] = x2[now << 1] + x2[now << 1 | 1];
} inline void query(int now, int l, int r, int x, int y)
{
if(x <= l && r <= y)
{
s += sum1[now];
xs += sum2[now];
xxs += sum3[now];
return;
}
push_down(now, l, r);
int mid = (l + r) >> 1;
if(x <= mid) query(ls, x, y);
if(mid < y) query(rs, x, y);
} inline LL gcd(LL x, LL y)
{
return !y ? x : gcd(y, x % y);
} int main()
{
LL g, z;
int i, x, y;
char c[10];
n = read();
m = read();
build(root);
while(m--)
{
scanf("%s", c);
if(c[0] == 'C')
{
x = read();
y = read();
z = read();
update(root, x, y - 1, z);
}
else
{
x = read();
y = read();
s = xs = xxs = 0;
query(root, x, y - 1);
ans2 = 1ll * (1 + y - x) * (y - x) / 2;
ans1 = 1ll * xs * (x + y - 1) - s * (1ll * x * y - y) - xxs;
g = gcd(ans1, ans2);
printf("%lld/%lld\n", ans1 / g, ans2 / g);
}
}
return 0;
}
一个longlong调了我45min,WNM
[luoguP2221] [HAOI2012]高速公路(线段树)的更多相关文章
- JZYZOJ1527 [haoi2012]高速公路 线段树 期望
http://172.20.6.3/Problem_Show.asp?id=1527 日常线段树的pushdown写挂,果然每次写都想得不全面,以后要注意啊……求期望部分也不熟练,和平均数搞混也是or ...
- 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}$ 下面倒是挺好算,组合数瞎搞 ...
- BZOJ 2752:[HAOI2012]高速公路(road)(线段树)
[HAOI2012]高速公路(road) Description Y901高速公路是一条重要的交通纽带,政府部门建设初期的投入以及使用期间的养护费用都不低,因此政府在这条高速公路上设立了许多收费站.Y ...
- 【线段树】BZOJ2752: [HAOI2012]高速公路(road)
2752: [HAOI2012]高速公路(road) Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1621 Solved: 627[Submit] ...
- 高速公路 [HAOI2012] [线段树]
Description Y901高速公路是一条重要的交通纽带,政府部门建设初期的投入以及使用期间的养护费用都不低,因此政府在这条高速公路上设立了许多收费站. Y901高速公路是一条由N-1段路以及N个 ...
- 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个收费站组成的东西 ...
随机推荐
- MD5 介绍
MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2.MD3和MD4发展而来.MD5算法的使用不需要支付任何版权费用. MD5功能: 输入任意 ...
- 微信程序开发系列教程(四)使用微信API创建公众号自定义菜单
大家可能经常看到一些微信公众号具有功能强大的自定义菜单,点击之后可以访问很多有用的功能. 这篇教程就教大家如何动手做一做. 这个教程最后实现的效果是:创建一个一级菜单"UI5", ...
- Codeforces Round #277.5 (Div. 2)-B. BerSU Ball
http://codeforces.com/problemset/problem/489/B B. BerSU Ball time limit per test 1 second memory lim ...
- python基础面试题整理---从零开始 每天十题(02)
书接上回,我们继续来说说python的面试题,我在各个网站搜集了一些,我给予你们一个推荐的答案,你们可以组织成自己的语言来说出来,让我们更好的做到面向工资编程 一.Q:说说你对zen of pytho ...
- POI写入word doc 03 模板的实例
在使用POI写word doc文件的时候我们必须要先有一个doc文件才行,因为我们在写doc文件的时候是通过HWPFDocument来写的,而HWPFDocument是要依附于一个doc文件的.所以通 ...
- 洛谷 P3958 奶酪
谨以此题来纪念我爆炸的NOIp2017 这个题虽然很多人说是并查集,但是搜索也是毫无压力的,考场搜索细节写挂,爆了个不上不下的80分.今天无意看到这道题,终于AC 首先这道题要考虑一下精度问题,虽然出 ...
- Ukulele 调音
正常的持琴姿势时,从上到下依次是:4,3,2,1弦,音从上往下是:G,C,E,A: 3弦 - C - Do - D - Re 2弦 - E - Mi - F - Fa 4弦 - G -So 1弦 - ...
- json 将key值以字符串形式取出
int GetJsonCString(const Json::Value& value, char* str, int n){ if (!value.empty() && va ...
- 对Fiddler设置【Decrypt HTTPS traffic】后火狐浏览器打开https【您的连接并不安全】的解决方法
火狐浏览器在打开https页面的时候出现[您的连接并不安全]的提示页面: 在设置Fiddler的HTTPS解密的时候,会对下面图中的红线框的选项点击一次生成一个Fiddler 根证书在桌面上: 点击火 ...
- Linux基础学习-使用PXE+Kickstart无人值守安装服务
无人值守安装系统 PXE(Preboot eXecute Environment,预启动执行环境)是由Intel公司开发的技术,可以让计算机通过网络来启动操作系统(前提是计算机上安装的网卡支持PXE技 ...