Description

有一条长度为n的链(1≤i<n,点i与点i+1之间有一条边的无向图),每个点有一个整数权值,第i个点的权值是

a_i。现在有m个操作,每个操作如下:

操作1(修改):给定链上两个节点u、v和一个整数d,表示将链上u到v唯一的简单路径上每个点权值都加上d。

操作2(询问):给定两个正整数L、r,表示求链上所有节点个数大于等于L且小于等于r的简单路径节点权值和之和。

由于答案很大,只用输出对质数1000000007取模的结果即可。

一条节点个数为k的简单路径节点权值和为这条上所有k个节点(包括端点)的权值之和,

而本题中要求是对所有满足要求的简单路径,求这一权值和的和。

由于是无向图,路径也是无向的,即点1到点2的路径与点2到点1的路径是同一条,不要重复计算。

Solution

开始想考虑每个点的贡献,然后发现要分三段讨论,并且维护的东西有点多,写不下去了

最后直接模拟题意:

设 \(s_i\) 为 \(a_i\) 的前缀和, \(ss_i\) 为 \(s_i\) 的前缀和

求 \(\sum_{k=l}^r\sum_{i=k}^n (s_i-s_{i-k})\)

\(\sum_{k=l}^r (\sum_{i=k}^{n}s_i-\sum_{i=0}^{n-k}s_i)\)

\(\sum_{k=l}^r (ss_n-ss_{k-1}-ss_{n-k})\)

\((r-l+1)*ss_n-\sum_{k=l-1}^{r-1}ss_k-\sum_{k=n-r}^{n-l}ss_k\)

线段树维护 \(ss\) 就好了

关于修改:

分两段考虑:

\(l<=i<=r\),\(ss_i\) 加上 \(d*\frac{(i-l+1)*(i-l+2)}{2}\)

\(r<i<=n\), \(ss_i\) 加上 \(d*(\frac{(r-l+1)*(r-l+2)}{2}+(r-l+1)*(i-r)*d)\)

分别是关于 \(i\) 的二次函数和一次函数

维护系数 \(a,b,c\) 就好了

#include<bits/stdc++.h>
#define ls (o<<1)
#define rs (o<<1|1)
using namespace std;
template<class T>void gi(T &x){
int f;char c;
for(f=1,c=getchar();c<'0'||c>'9';c=getchar())if(c=='-')f=-1;
for(x=0;c<='9'&&c>='0';c=getchar())x=x*10+(c&15);x*=f;
}
const int N=2e5+10,mod=1e9+7,inv=166666668,inv2=500000004;
int n,Q,a[N],s[N],ss[N],tr[N*4],A[N*4],B[N*4],C[N*4];
int la,lb,lc;
inline int S1(int l,int r){return (1ll*(l+r)*(r-l+1)>>1)%mod;}
inline int S2(int l,int r){
int rr=1ll*r*(r+1)%mod*((r<<1)+1)%mod;l--;
int ll=1ll*l*(l+1)%mod*((l<<1)+1)%mod;
return 1ll*(rr-ll+mod)*inv%mod;
}
inline void upd(int o){tr[o]=(tr[ls]+tr[rs])%mod;}
inline void build(int l,int r,int o){
if(l==r){tr[o]=ss[l];return ;}
int mid=(l+r)>>1;
build(l,mid,ls);build(mid+1,r,rs);
upd(o);
}
inline void pushdown(int o,int l,int r){
if(!A[o]&&!B[o]&&!C[o])return ;
int mid=(l+r)>>1;
A[ls]=(A[ls]+A[o])%mod;B[ls]=(B[ls]+B[o])%mod;C[ls]=(C[ls]+C[o])%mod;
A[rs]=(A[rs]+A[o])%mod;B[rs]=(B[rs]+B[o])%mod;C[rs]=(C[rs]+C[o])%mod; tr[ls]=(tr[ls]+1ll*S2(l,mid)*A[o])%mod;
tr[ls]=(tr[ls]+1ll*S1(l,mid)*B[o])%mod;
tr[ls]=(tr[ls]+1ll*(mid-l+1)*C[o])%mod;
tr[rs]=(tr[rs]+1ll*S2(mid+1,r)*A[o])%mod;
tr[rs]=(tr[rs]+1ll*S1(mid+1,r)*B[o])%mod;
tr[rs]=(tr[rs]+1ll*(r-mid)*C[o])%mod; A[o]=B[o]=C[o]=0;
}
inline void mdf(int l,int r,int o,int sa,int se){
if(sa<=l && r<=se){
A[o]=(A[o]+la)%mod;B[o]=(B[o]+lb)%mod;C[o]=(C[o]+lc)%mod;
tr[o]=(tr[o]+1ll*S2(l,r)*la)%mod;
tr[o]=(tr[o]+1ll*S1(l,r)*lb)%mod;
tr[o]=(tr[o]+1ll*(r-l+1)*lc)%mod;
return ;
}
pushdown(o,l,r);
int mid=(l+r)>>1;
if(se<=mid)mdf(l,mid,ls,sa,se);
else if(sa>mid)mdf(mid+1,r,rs,sa,se);
else mdf(l,mid,ls,sa,mid),mdf(mid+1,r,rs,mid+1,se);
upd(o);
}
inline int qry(int l,int r,int o,int sa,int se){
if(sa<=l && r<=se)return tr[o];
pushdown(o,l,r);
int mid=(l+r)>>1;
if(se<=mid)return qry(l,mid,ls,sa,se);
if(sa>mid)return qry(mid+1,r,rs,sa,se);
return (qry(l,mid,ls,sa,mid)+qry(mid+1,r,rs,mid+1,se))%mod;
}
int main(){
freopen("pp.in","r",stdin);
freopen("pp.out","w",stdout);
cin>>n>>Q;
for(int i=1;i<=n;i++)
gi(a[i]),s[i]=(s[i-1]+a[i])%mod,ss[i]=(ss[i-1]+s[i])%mod;
build(1,n,1);
int op,x,y,z;
while(Q--){
gi(op);gi(x);gi(y);
if(x>y)swap(x,y);
if(op==1){
gi(z);
z=1ll*z*inv2%mod;
la=z;lb=1ll*(3-2*x)*z%mod;lc=1ll*z*((1ll*x*x-3*x+2)%mod)%mod;
if(lb<0)lb+=mod;if(lc<0)lc+=mod;
mdf(1,n,1,x,y);
if(y<n){
z=1ll*z*2%mod;
la=0;lb=1ll*(y-x+1)*z%mod;
lc=(1ll*z*((1ll*(y-x+1)*(y-x+2)/2-1ll*(y-x+1)*y)%mod))%mod;
if(lc<0)lc+=mod;
mdf(1,n,1,y+1,n);
}
}
else{
int ans=1ll*(y-x+1)*qry(1,n,1,n,n)%mod;
if(y-1>0)ans=(1ll*ans-qry(1,n,1,max(x-1,1),y-1)+mod)%mod;
if(n-x>0)ans=(1ll*ans-qry(1,n,1,max(n-y,1),n-x)+mod)%mod;
printf("%d\n",ans);
}
}
return 0;
}

bzoj 5291: [Bjoi2018]链上二次求和的更多相关文章

  1. 【BZOJ5291】[BJOI2018]链上二次求和(线段树)

    [BZOJ5291][BJOI2018]链上二次求和(线段树) 题面 BZOJ 洛谷 题解 考虑一次询问\([l,r]\)的答案.其中\(S\)表示前缀和 \(\displaystyle \sum_{ ...

  2. BZOJ5291/洛谷P4458/LOJ#2512 [Bjoi2018]链上二次求和 线段树

    原文链接http://www.cnblogs.com/zhouzhendong/p/9031130.html 题目传送门 - LOJ#2512 题目传送门 - 洛谷P4458 题目传送门 - BZOJ ...

  3. BZOJ5291 BJOI2018链上二次求和(线段树)

    用线段树对每种长度的区间维护权值和. 考虑区间[l,r]+1对长度为k的区间的贡献,显然其为Σk-max(0,k-i)-max(0,k-(n-i+1)) (i=l~r). 大力展开讨论.首先变成Σk- ...

  4. [BZOJ5291][BJOI2018]链上二次求和(线段树)

    感觉自己做的麻烦了,但常数似乎不算差.(只是Luogu最慢的点不到2s本地要跑10+s) 感觉我的想法是最自然的,但不明白为什么网上似乎找不到这种做法.(不过当然所有的做法都是分类大讨论,而我的方法手 ...

  5. 2018.01.04 bzoj5291: [Bjoi2018]链上二次求和(线段树)

    传送门 线段树基础题. 题意:给出一个序列,要求支持区间加,查询序列中所有满足区间长度在[L,R][L,R][L,R]之间的区间的权值之和(区间的权值即区间内所有数的和). 想题555分钟,写题202 ...

  6. loj2512 [BJOI2018]链上二次求和

    传送门 分析 咕咕咕 代码 #include<iostream> #include<cstdio> #include<cstring> #include<st ...

  7. 洛谷P4458 /loj#2512.[BJOI2018]链上二次求和(线段树)

    题面 传送门(loj) 传送门(洛谷) 题解 我果然是人傻常数大的典型啊-- 题解在这儿 //minamoto #include<bits/stdc++.h> #define R regi ...

  8. 「BJOI2018」链上二次求和

    「BJOI2018」链上二次求和 https://loj.ac/problem/2512 我说今天上午写博客吧.怕自己写一上午,就决定先写道题. 然后我就调了一上午线段树. 花了2h找到lazy标记没 ...

  9. 【LOJ】#2512. 「BJOI2018」链上二次求和

    题面 题解 转化一下可以变成所有小于等于r的减去小于等于l - 1的 然后我们求小于等于x的 显然是 \(\sum_{i = 1}^{n} \sum_{j = 1}^{min(i,x)} sum[i] ...

随机推荐

  1. 谷歌Google浏览器去广告插件ABP插件安装与使用

    ---恢复内容开始--- 最新版本的 Chrome 浏览器,主版本号为 67,数字签名日期为 2018.05.30.对 Chrome 的扩展(俗称插件)安装策略进行了调整——只允许在 Chrome 应 ...

  2. this指针------新标准c++程序设计

    背景:   c++是在c语言的基础上发展而来的,第一个c++的编译器实际上是将c++程序翻译成c语言程序,然后再用c语言编译器进行编译.c语言没有类的概念,只有结构,函数都是全局函数,没有成员函数.翻 ...

  3. C# 密封

    到目前位置所说的都是让类如何如何进行继承啊 ,重写啊,巴不得类有十多个继承,超级多的重写. 但是,今天我们来说说不允许继承和不允许重写! 这个不允许继承是包括类和方法. 这种情况好比: 爸爸有私房钱, ...

  4. Jmeter_远程启动

    Jmeter 是Java 应用,对于CPU和内存的消耗比较大,因此,当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至会引起JAVA内存溢出错误. 其实,Jmeter的 ...

  5. loj #6342. 跳一跳

    #6342. 跳一跳 题目描述 现有一排方块,依次编号为 1…n1\ldots n1…n.方块 111 上有一个小人,已知当小人在方块 iii 上时,下一秒它会等概率地到方块 iii(即不动),方块  ...

  6. spark-2.2.1在centos7安装

    前言 在安装Spark之前,我们需要安装Scala语言的支持.在此我选择的是scala-2.11.12版本.jdk8也要保证已经安装好并且配置好环境变量 scala-2.11.12下载 为了方便,我先 ...

  7. jeecms学习笔记

    jeecms学习笔记 内容管理系统 1.栏目列表标签 作用:获取栏目的列表 [@cms_channel_list] [#list tag_list as b] <a href="${b ...

  8. 决策树--Python

    决策树 实验集数据: #coding:utf8 #关键词:决策树(desision tree).特征选择.信息增益(information gain).香农熵.熵(entropy).经验熵(H(D)) ...

  9. 12、OpenCV Python 图像梯度

    __author__ = "WSX" import cv2 as cv import numpy as np def lapalian_demo(image): #拉普拉斯算子 # ...

  10. vue 路由导航白话全解析

    这里先放上官网的教程和说明:点击这里,vue导航守卫官方文档 路由守卫 路由守卫说白了就是路由拦截,在地址栏跳转之前 之后 跳转的瞬间 干什么事 全局守卫 全局守卫顾名思义,就是全局的,整个项目所有路 ...