题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3529

挺恶心的数论TAT。。。

设f[i]是i的约数和,这个可以nln(n)扫出来。

ans=∑d[n/d]*[m/d]*∑i|d f[i]*μ[d/i]

然后由于只有f[i]<=a是有用的,所以对给的a从小到大排序,对求的f[i]从小到大排序,用个树状数组维护一下。

由于分块思想,可以枚举d,然后会出现一段n/i是一样的,所以把那部分区间求和就可以了。

#include<cstring>
#include<iostream>
#include<algorithm>
#include<cstdio>
#define rep(i,l,r) for (int i=l;i<=r;i++)
#define down(i,l,r) for (int i=l;i>=r;i--)
#define clr(x,y) memset(x,y,sizeof(x))
#define inf 1000000009
#define ll long long
#define maxn 100500
#define mm 2147483648
#define low(x) (x&(-x))
using namespace std;
struct data{int a,n,m,b,id;
}a[maxn];
struct node{int a;int b;
}f[maxn];
int tot,mx,T,b[maxn],pri[maxn],mu[maxn],ans[maxn];
int t[maxn];
int read(){
int x=,f=; char ch=getchar();
while (!isdigit(ch)){if (ch=='-') f=-; ch=getchar();}
while (isdigit(ch)){x=x*+ch-''; ch=getchar();}
return x*f;
}
bool cmpa(data a,data b){
return a.a<b.a;
}
bool cmp(node a,node b){
return a.a<b.a;
}
void pre(){
mu[]=;
rep(i,,mx){
if (!b[i]) b[i]=,pri[++tot]=i,mu[i]=-;
rep(j,,tot)if (i*pri[j]<=mx){
b[i*pri[j]]=;
if (i%pri[j]==) {mu[i*pri[j]]=; break;}
else mu[i*pri[j]]=-mu[i];
}
else break;
}
rep(i,,mx)
for (int j=i;j<=mx;j+=i) f[j].a+=i;
rep(i,,mx) f[i].b=i;
}
void add(int x,int y){
while (x<=mx){
t[x]+=y; x+=low(x);
}
}
int ask(int x){
int ans=;
while (x){
ans+=t[x];
x-=low(x);
}
return ans;
}
void solve(int id){
int n=a[id].n,m=a[id].m;
for (int i=,j;i<=n;i=j+){
j=min(n/(n/i),m/(m/i));
ans[a[id].id]+=(n/i)*(m/i)*(ask(j)-ask(i-));
}
}
int main(){
int q=read();
rep(i,,q){
a[i].n=read(); a[i].m=read(); a[i].a=read(); a[i].id=i;
if (a[i].n>a[i].m) swap(a[i].n,a[i].m);
mx=max(mx,a[i].n);
}
pre();
sort(a+,a++q,cmpa);
sort(f+,f++mx,cmp);
int now=;
rep(i,,q){
while (f[now].a<=a[i].a&&now<=mx){
for (int j=f[now].b;j<=mx;j+=f[now].b){
add(j,f[now].a*mu[j/f[now].b]);
}
now++;
}
solve(i);
}
rep(i,,q) printf("%d\n",ans[i]&0x7fffffff);
return ;
}

BZOJ3529: [Sdoi2014]数表的更多相关文章

  1. [bzoj3529][Sdoi2014]数表_树状数组_莫比乌斯反演

    数表 bzoj-3529 Sdoi-2014 题目大意:n*m的数表,第i行第j列的数是同时整除i和j的所有自然数之和.给定a,求数表中所有不超过a的和. 注释:$1\le n,m \le 10^5$ ...

  2. BZOJ3529 [Sdoi2014]数表 【莫比乌斯反演】

    3529: [Sdoi2014]数表 Time Limit: 10 Sec Memory Limit: 512 MB Submit: 2151 Solved: 1080 [Submit][Status ...

  3. bzoj千题计划205:bzoj3529: [Sdoi2014]数表

    http://www.lydsy.com/JudgeOnline/problem.php?id=3529 有一张n*m的数表,其第i行第j列(1 < =i < =n,1 < =j & ...

  4. BZOJ3529 [Sdoi2014]数表【莫比乌斯反演】

    Description 有一张 n×m 的数表,其第 i 行第 j 列(1 <= i <= n, 1 <= j <= m)的数值为 能同时整除 i 和 j 的所有自然数之和.给 ...

  5. 莫比乌斯反演套路二--(n/d)(m/d)给提出来--BZOJ3529: [Sdoi2014]数表

    一个数表上第i行第j列表示能同时整除i和j的自然数,Q<=2e4个询问,每次问表上1<=x<=n,1<=y<=m区域内所有<=a的数之和.n,m<=1e5,a ...

  6. BZOJ3529: [Sdoi2014]数表(莫比乌斯反演,离线)

    Description 有一张 n×m 的数表,其第 i 行第 j 列(1 <= i <= n, 1 <= j <= m)的数值为 能同时整除 i 和 j 的所有自然数之和.给 ...

  7. bzoj3529: [Sdoi2014]数表 莫比乌斯反演

    题意:求\(\sum_{i=1}^n\sum_{j=1}^nf(gcd(i,j))(gcd(i,j)<=a),f(x)是x的因子和函数\) 先考虑没有限制的情况,考虑枚举gcd为x,那么有\(\ ...

  8. BZOJ3529: [Sdoi2014]数表(莫比乌斯反演 树状数组)

    题意 题目链接 Sol 首先不考虑\(a\)的限制 我们要求的是 \[\sum_{i = 1}^n \sum_{j = 1}^m \sigma(gcd(i, j))\] 用常规的套路可以化到这个形式 ...

  9. 题解【bzoj3529 [SDOI2014]数表】

    Description \(T\) 组询问,定义 \(F(n)=\sum\limits_{d|n}d\).每次给出 \(n,m,a\) 求 \[\sum\limits_{i=1,j=1,F(\gcd( ...

随机推荐

  1. 基于Vue的SPA动态修改页面title的方法

    最近基于VUE做个SPA手机端web发现动态修改页面标题通过document.title=xxxx 来修改着实蛋疼,而且在IOS的微信端据说没效果.百度发现要针对IOS的微信做点额外的操作,即:创建一 ...

  2. signalr中Group 分组群发消息的简单使用

    前一段时间写了几篇关于signalr的文章 1.MVC中使用signalR入门教程 2.mvc中signalr实现一对一的聊天 3.Xamarin android中使用signalr实现即时通讯 在平 ...

  3. discuz管理员登录进入后台管理马上跳转到登录界面

    昨天尝试了一下这个discuz论坛,感觉还可以.今天刚刚用管理员账户进入后台管理,准备改一改界面熟悉一下,过不了10秒钟.老是马上就退出来了.我想起来了,昨天是在阿里云服务器上面直接登录这个管理员账号 ...

  4. ExperDot的博客目录导航

    最近活动 我更新了博客!粒子系统:从零开始画一棵树 Github:[ UWP ] [ JavaScript ] 自然编程  奇幻元纪 上帝创世篇:如何画一颗静态树 女娲补天篇:仿人工拼接碎片 吴刚伐桂 ...

  5. ArcGIS API for JavaScript 4.2学习笔记[9] 同一种视图不同数据(Map)同步

    本例子核心:对MapView对象的map属性值进行替换即可达到更改地图数据的效果. 这个例子用的不是Map对象了,而是用的发布在服务器上的专题地图(WebMap)来加载到MapView上进行显示. 在 ...

  6. ArcGIS API for JavaScript 4.2学习笔记[12] View的弹窗(Popup)

    看本文前最好对第二章(Mapping and Views)中的Map和View类有理解. 视图类有一个属性是Popup类型的popup,查阅API知道这个就是视图的弹窗,每一个View的实例都有一个p ...

  7. php程序员面试经验

    面试是你进入公司的第一个关卡,面试过后还会有试用期.可有时候总有那么一些人对待面试完全没人任何防备. 如果你想进入一家优秀的企业,那么对于面试你一定要做好十足的准备.为什么说了:"将军不打没 ...

  8. 在win7下用net命令无法实现对用户的创建(未完成)

    ============================================================================================= 201307 ...

  9. js获取手机屏幕宽度、高度

    网页可见区域宽:document.body.clientWidth 网页可见区域高:document.body.clientHeight 网页可见区域宽:document.body.offsetWid ...

  10. MarkDown的用法

    # 一级标题## 二级标题### 三级标题#### 四级标题##### 五级标题###### 六级标题# 无序标题- 文本- 文本- 文本# 有序标题1. 文本2. 文本3. 文本# 图片链接[张驰博 ...