题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4815

大概就是推式子的时候注意有两个边界都是 n ,考虑变成 2*... 之类的。

分块维护 f[ ] 的前缀和。很好的思路是修改一个位置后前缀和数组需要区间加,整块地打上加法标记就行了。

自己本来想维护整块之间的前缀和,还有块内的前缀和;却WA得不行。之后再探究为什么WA吧。

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define ll long long
using namespace std;
const int N=4e6+,M=,mod=1e9+;
int n,g[N],phi[N],f[N],pri[N];bool vis[N];
int base,bh[N],s[M],si[M],fl[N];
void upd(int &x){while(x>=mod)x-=mod;while(x<)x+=mod;}
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int pw(int x,int k)
{int ret=;while(k){if(k&)ret=(ll)ret*x%mod;x=(ll)x*x%mod;k>>=;}return ret;}
void init()
{
phi[]=g[]=; int cnt=;
for(int i=;i<=n;i++)
{
if(!vis[i])pri[++cnt]=i,phi[i]=i-;
for(int j=;j<=cnt&&(ll)i*pri[j]<=n;j++)
{
vis[i*pri[j]]=;
if(i%pri[j]==){phi[i*pri[j]]=(ll)phi[i]*pri[j]%mod;break;}
else phi[i*pri[j]]=(ll)phi[i]*phi[pri[j]]%mod;
}
g[i]=(g[i-]+(ll)i*i%mod*phi[i])%mod;//presum!!
}
base=sqrt(n);
for(int i=;i<=n;i++)f[i]=(ll)i*i%mod,fl[i]=(fl[i-]+f[i])%mod;
for(int i=,j=,k=;i<=n;i++,k++)
{
bh[i]=j;if(k==base)k=,j++;
}
/*
for(int i=1,j=1,k=base;i<=n;i++)
{
f[i]=(ll)i*i%mod;bh[i]=j;
si[j]+=f[i]; upd(si[j]); fl[i]=si[j];
if(i==k)s[j]=s[j-1]+si[j],j++,k+=base;
}
*/
}
int calc(int x){int ret=fl[x]+s[bh[x]];upd(ret);return ret;}
int main()
{
int T;scanf("%d%d",&T,&n);init();
int x,y,tn; ll w;
while(T--)
{
scanf("%d%d%lld%d",&x,&y,&w,&tn);//w not %mod!!!
int u=gcd(x,y),d=bh[u];
int tf=w/(x/u)/(y/u)%mod;//not inv /*//also ok
int chg=tf+calc(u-1)-calc(u);upd(chg);
for(int i=u;bh[i]==bh[u];i++)
fl[i]+=chg,upd(fl[i]);
for(int i=bh[u]+1;i<=bh[n];i++)//n not tn!!!
s[i]+=chg,upd(s[i]);
*/
int pl=tf-f[u];upd(pl);f[u]=tf;
for(int i=u;bh[i]==bh[u];i++)
fl[i]+=pl,upd(fl[i]);
for(int i=bh[u]+;i<=bh[n];i++)
s[i]+=pl,upd(s[i]);
/*
si[d]=si[d]-f[u]+tf;upd(si[d]);
for(int i=d;i<=bh[n];i++)
s[i]=s[i-1]+si[i],upd(s[i]);
f[u]=tf; fl[u]=(bh[u-1]==bh[u]?fl[u-1]:0)+f[u];
for(int i=u+1,j=d*base;i<=j;i++)
fl[i]=fl[i-1]+f[i],upd(fl[i]);
*/
int ans=;
for(int i=,j;i<=tn;i=j+)
{
int d=tn/i,sm=; j=tn/d;
/*
if(bh[j]-bh[i]<=1)
for(int l=i;l<=j;l++)
sm+=f[l],upd(sm);
else
{
sm=s[bh[j]-1]-s[bh[i]-1]+fl[j];
upd(sm);
if(bh[i-1]==bh[i])sm-=fl[i-1],upd(sm);
}
ans=(ans+(ll)sm*g[d])%mod;
*/
ans=(ans+(ll)(calc(j)-calc(i-))*g[d])%mod;upd(ans);
}
printf("%d\n",ans);
}
return ;
}

bzoj 4815 [Cqoi2017]小Q的表格——反演+分块的更多相关文章

  1. bzoj 4815: [Cqoi2017]小Q的表格 [数论]

    4815: [Cqoi2017]小Q的表格 题意: 单点修改,查询前缀正方形和.修改后要求满足条件f(a,b)=f(b,a), b×f(a,a+b)=(a+b)*f(a,b) 一开始sb了认为一次只会 ...

  2. bzoj 4815: [Cqoi2017]小Q的表格【欧拉函数+分块】

    参考:http://blog.csdn.net/qq_33229466/article/details/70174227 看这个等式的形式就像高精gcd嘛-所以随便算一下就发现每次修改(a,b)影响到 ...

  3. BZOJ 4815 CQOI2017 小Q的表格 欧拉函数+分块

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4815 题意概述:要认真概述的话这个题就出来了... 分析: 首先分析题目,认真研究一下修 ...

  4. BZOJ 4815 [Cqoi2017]小Q的表格 ——欧拉函数

    把式子化简一波. 发现一个比较厉害的性质:每个点只能影响到行列下标$gcd$与它相同的点. 然后就可以计算$\sum_{g<=k}f(g,g)*\sum_{i<=k}\sum_{j< ...

  5. [CQOI2017]小Q的表格(数论+分块)

    题目描述 小Q是个程序员. 作为一个年轻的程序员,小Q总是被老C欺负,老C经常把一些麻烦的任务交给小Q来处理.每当小Q不知道如何解决时,就只好向你求助. 为了完成任务,小Q需要列一个表格,表格有无穷多 ...

  6. bzoj 4815 小Q的表格 —— 反演+分块

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4815 思路就和这里一样:https://blog.csdn.net/leolyun/arti ...

  7. 4815: [Cqoi2017]小Q的表格 莫比乌斯反演 分块

    (Updated 2018.04.28 : 发现公式效果不好,重新处理图片)国际惯例的题面:看到这两个公式,很多人都会想到与gcd有关.没错,最终的结论就是f(a,b)=f(gcd(a,b))*(a/ ...

  8. [CQOI2017]小Q的表格——反演好题

    zhoutb2333的题解 难得一见的新颖反演题. 一眼看可能不是反演题. 修改影响别的,很恶心. 所以考虑化简f的联系式,发现和gcd有关 于是考虑用gcd来表示所有的gcd(a,b)=g的所有f( ...

  9. [BZOJ4815][CQOI2017]小Q的表格 数论+分块

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=4815 题目中所给条件中的$(a,a+b)$和$(a,b)$的关系很瞩目. 然后大家都知道$ ...

随机推荐

  1. 2018.2.2IDEA 项目层级问题

    这个问题也不是太大,个人爱好,老是觉着影响美观.网上找了一下:[Hide Empty Middle Packages]说是把这个打勾的去掉就可以了. 但是:我的这个好像没有. 这样点击小齿轮把第二个C ...

  2. ResultSet 结果集

    转自:http://blog.csdn.net/z93971401/article/details/7469503 这篇文章并没有给出如何使用ResultSet的具体例子,只是从ResultSet的功 ...

  3. UVALive-3211 Now or later (2-SAT+二分)

    题目大意:有n架飞机,每架飞机有两个可选择的着陆时间,并且每架飞机都必须要选一个时间着陆.为了安全考虑,要求两架飞机的最小着陆时间差最大,找出这个最大值. 题目分析:有“最小值的最大值”这样的字眼,用 ...

  4. Jquery Json解析

    JSON的优点: 1.基于纯文本,跨平台传递极其简单: 2.Javascript原生支持,后台语言几乎全部支持: 3.轻量级数据格式,占用字符数量极少,特别适合互联网传递: 4.可读性较强,虽然比不上 ...

  5. 解决xadmin下设置“use_bootswatch = True”无效的问题

    环境:python 2.7django 1.9xadmin采用源代码的方式引入到项目中QQ群交流:697028234 1.安装requests pip install requests 2./xadm ...

  6. 【css】CSS3 Media Queries 详解【转】

    说起CSS3的新特性,就不得不提到 Media Queries .最近 Max Design 更新的一个泛读列表里,赫然就有关于 Media Queries 的文章.同时位列其中的也有前天我刚刚翻译的 ...

  7. C++11_ tuple

    版权声明:本文为博主原创文章,未经博主允许不得转载. tuple 是一个可以装载任何变量的容器,C++11的Variadic Templates给tuple的实现带来了极大方便. tuple的实现基于 ...

  8. 马士兵_JAVA自学之路(为那些目标模糊的码农们)

    转载自:http://blog.csdn.net/anlidengshiwei/article/details/42264301 JAVA自学之路 一:学会选择 为了就业,不少同学参加各种各样的培训. ...

  9. Linux:运行级别,root密码重置,救援模式,安装图形化界面

    运行级别,root密码重置,救援模式,安装图形界面 运行级别 1.查看当前系统的运行级别 runlevel 2.认识各个运行级别以及开机自启运行级别 Linux系统运行级别共7个执行 vi /etc/ ...

  10. CSS 清除浮动 clear 属性

    CSS 清除浮动 clear 属性用于设定元素哪一侧不允许有其他浮动元素(而并非取消元素的浮动). 可能的取值如下: 取值 说明 none 默认值,允许两侧都有浮动元素 left 左侧不允许有其他浮动 ...