bzoj [SDOI2014]数表 莫比乌斯反演 BIT

链接

bzoj

luogu

loj

思路

\[\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}a*[f[gcd(i,j)]<=a]
\]

\[f[]可以O(n)预处理出来
\]

\[\sum\limits_{k=1}^{n}f[k]*\sum\limits_{i=1}^{m}\sum\limits_{j=1}^{m}[gcd(i,j)==k]
\]

\[\sum\limits_{k=1}^{n}f[k]*\sum\limits_{i=1}^{\frac{n}{k}}{\frac{n}{ki}}{\frac{m}{ki}}\mu(i)
\]

\[\sum\limits_{i=1}^{n}f[i]*\sum\limits_{k|d}{\frac{n}{d}\frac{m}{d}}\mu(\frac{d}{i})
\]

d替换k*i

\[\sum\limits_{d=1}^{n} \frac{n}{d} \frac{m}{d} \sum\limits_{k|d} \mu(\frac{d}{k})f(k)
\]

\[\sum\limits_{d=1}^{n} \frac{n}{d} \frac{m}{d} g(d)
\]

\[g(d)=\sum\limits_{k|d} \mu(\frac{d}{k})f(k)
\]

询问按照a排序,每次加入f(k)时候影响的只是能k|d的g(d)

每次修改就是\(O(\sqrt{n}logn)\)

查询也是一样,

总的就是\(O(T\sqrt{n}logn)\)

注意,ll+取模的话,loj会超时,用int的自然溢出就快了三倍(300ms),是int,不是unsigned int。

其他

线性筛约数和

\[x=p_{1}^{w_1}p_{2}^{w_2}…p_{k}^{w_k}
\]

那么

\[SD(x)=约数和=(1+p_1^1+p_1^2+…+p_1^{w_1})(1+p_2^1+p_2^2+…+p_2^{w_2})(1+p_k^1+p_k^2+…+p_k^{w_k})
\]

0x00 是个素数

显然\(SD(pri)=pri+1\)

0x01 两两互质

是个积性函数

因为x,y两两互质,所以他们质因子互不相交,所以显然脑补公式

\[SD(x*y)=SD(x)*SD(y)(gcd(x,y)==1)
\]

0x02 两两不互质(i%pri[j]!=0)

再开个数组tmp,记录最小质因子因子的贡献\((1+p_1^1+p_1^2+…+p_1^{w_1})\)

因为pri[j]是他的最小质因子(因为这是线性筛)

我们之前求出的i的

\[SD(i)=(1+p_1^1+p_1^2+…+p_1^{w_1})(1+p_2^1+p_2^2+…+p_2^{w_2})(1+p_k^1+p_k^2+…+p_k^{w_k})
\]

现在的\(i*pri[j]\)的SD显然就是

\[SD(i*pri[j])=(1+p_1^1+p_1^2+…+p_1^{w_1}+p_1^{w_1+1})(1+p_2^1+p_2^2+…+p_2^{w_2})(1+p_k^1+p_k^2+…+p_k^{w_k})
\]

改变的只有最小因子的贡献,tmp的作用就来了

tmp[i]我们已经求出来了,那么

\[tmp[i*pri[j]]=tmp[i]*pri[j]+1(这是个等差数列)
\]

\[SD[i*pri[j]]=SD[i]/tmp[i]*tmp[i*pri[j]]
\]

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 6;
int read() {
int x = 0, f = 1; char s = getchar();
for (; s > '9' || s < '0'; s = getchar()) if (s == '-') f = -1;
for (; s >= '0' && s <= '9'; s = getchar()) x = x * 10 + s - '0';
return x * f;
}
int pri[N], tot, vis[N], mu[N];
int f[N], tmp[N];
struct node {
int n, m, a, id;
int ans;
bool operator < (const node &b) const {
return a < b.a;
}
} Q[N];
bool cmp(node a, node b) {
return a.id < b.id;
}
pair<int,int> F[N];
void Euler(int limit) {
f[1] = tmp[1] = mu[1] = 1;
for (int i = 2; i <= limit; ++i) {
if (!vis[i]) {
mu[i] = -1;
pri[++tot] = i;
f[i] = i + 1;
tmp[i] = i + 1;
}
for (int j = 1; j <= tot && i * pri[j] <= limit; ++j) {
vis[i * pri[j]] = 1;
if (i % pri[j] == 0) {
tmp[i * pri[j]] = tmp[i] * pri[j] + 1;
f[i * pri[j]] = f[i] / tmp[i] * tmp[i * pri[j]];
mu[i * pri[j]] = 0;
break;
}
mu[i * pri[j]] = -mu[i];
f[i * pri[j]] = f[i] * f[pri[j]];
tmp[i * pri[j]] = pri[j] + 1;
}
}
for (int i = 1; i <= limit; ++i) {
F[i].first = f[i], F[i].second = i;
}
sort(F + 1, F + 1 + limit);
}
namespace BIT {
int sum[N];
int lowbit(int x) {return x & (-x);}
void add(int x, int ad) {
for (int i = x; i <= 100000; i += lowbit(i)) sum[i] = (sum[i] + ad);
}
int query(int x) {
int ans = 0;
for (int i = x; i >= 1; i -= lowbit(i)) ans = (ans + sum[i]);
return ans;
}
}
int main() {
Euler(100000);
int T = read();
for (int i = 1; i <= T; ++i) {
Q[i].n = read(),Q[i].m = read(),Q[i].a = read(), Q[i].id = i;
}
sort(Q + 1, Q + 1 + T);
int now = 0;
for (int i = 1; i <= T; ++i) {
while (now + 1 <= 100000 && Q[i].a >= F[now + 1].first) {
now++;
for (int j = F[now].second; j <= 100000; j += F[now].second) {
BIT::add(j, mu[j / F[now].second] * F[now].first);
}
}
int ans = 0;
if (Q[i].n > Q[i].m) swap(Q[i].n, Q[i].m);
for (int l = 1, r; l <= Q[i].n; l = r + 1) {
r = min(Q[i].n / (Q[i].n / l), Q[i].m / (Q[i].m / l));
ans += 1LL * (Q[i].n / l) * (Q[i].m / l) * (BIT::query(r) - BIT::query(l - 1));
}
Q[i].ans = ans;
}
sort(Q + 1, Q + 1 + T, cmp);
for (int i = 1; i <= T; ++i) printf("%u\n", Q[i].ans < 0 ? Q[i].ans + 2147483648 : Q[i].ans);
return 0;
}

bzoj [SDOI2014]数表 莫比乌斯反演 BIT的更多相关文章

  1. BZOJ[Sdoi2014]数表 莫比乌斯反演

    [Sdoi2014]数表 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 2383  Solved: 1229[Submit][Status][Disc ...

  2. BZOJ 3259 [Sdoi2014]数表 (莫比乌斯反演 + 树状数组)

    3529: [Sdoi2014]数表 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 2321  Solved: 1187[Submit][Status ...

  3. BZOJ 3529: [Sdoi2014]数表 [莫比乌斯反演 树状数组]

    3529: [Sdoi2014]数表 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1399  Solved: 694[Submit][Status] ...

  4. BZOJ 3529 [Sdoi2014]数表 (莫比乌斯反演+树状数组+离线)

    题目大意:有一张$n*m$的数表,第$i$行第$j$列的数是同时能整除$i,j$的所有数之和,求数表内所有不大于A的数之和 先是看错题了...接着看对题了发现不会做了...刚了大半个下午无果 看了Po ...

  5. 【BZOJ3529】[Sdoi2014]数表 莫比乌斯反演+树状数组

    [BZOJ3529][Sdoi2014]数表 Description 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为能同时整除i和 ...

  6. 【bzoj3529】[Sdoi2014]数表 莫比乌斯反演+离线+树状数组

    题目描述 有一张n×m的数表,其第i行第j列(1 <= i <= n ,1 <= j <= m)的数值为能同时整除i和j的所有自然数之和.给定a,计算数表中不大于a的数之和. ...

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

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

  8. BZOJ 3529 [Sdoi2014]数表 ——莫比乌斯反演 树状数组

    $ans=\sum_{i=1}^n\sum_{j=1}^n\sigma(gcd(i,j))$ 枚举gcd为d的所有数得到 $ans=\sum_{d<=n}\sigma(d)*g(d)$ $g(d ...

  9. bzoj 3529 数表 莫比乌斯反演+树状数组

    题目大意: 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为能同时整除i和j的所有自然数之和.给定a,计算数表中不大于a的数之和. ...

随机推荐

  1. Eureka概述

    1:Eureka是什么 Eureka是Spring Cloud Netflix的一个子模块,也是核心模块之一.Eureka是一个基于REST的服务,用于定位服务,以及·实现云端中间层服务发现和故障转移 ...

  2. Ubuntu16 安装 wireshark

    添加源 sudo apt-add-repository ppa:wireshark-dev/stable 更新 sudo apt-get update 安装 sudo apt-get install ...

  3. 【01】Jenkins:安装配置

    写在前面的话 从我的工作经历来看,刚出来的时候的第一家公司我们上线采用的是脚本上线.就是那种开发合并完代码以后,在一个固定的时间点,我们上服务器执行更新脚本打包更新.这种方法有一个很大的问题,就是对于 ...

  4. Lambda表达式的用法

    参考:https://www.cnblogs.com/knowledgesea/p/3163725.html

  5. Quartz.Net 删除一个Job

    Quartz.Net 删除Job 来博客园的第一篇文章先写个简单的,希望能帮助到大家. 步入正题: Quartz.Net有三个重要的概念,分别是 Scheduler .Job .Trigger.  S ...

  6. 我是如何一步步编码完成万仓网ERP系统的(四)登录的具体实现

    https://www.cnblogs.com/smh188/p/11533668.html(我是如何一步步编码完成万仓网ERP系统的(一)系统架构) https://www.cnblogs.com/ ...

  7. C#中几种单例模式

    1.静态代码块 /// <summary> /// 静态代码块 /// 仅在第一次调用类的任何成员时自动执行 /// </summary> public class Singl ...

  8. JavaScript 总结[目录]

    ECMAScript 基础 一.JavaScript 基础 1.1 JavaScript 简介 1.2 JavaScript 书写位置 二.JavaScript 数据类型 2.1 JavaScript ...

  9. c语言-数组、指针面试题

    转载 说明:所有题目均摘录于网络以及我所见过的面试题目,欢迎补充! 无特殊说明情况下,下面所有题s目都是linux下的32位C程序. 先来几个简单的热热身. 1.计算以下sizeof的值. char ...

  10. Linux操作系统的压缩、解压缩工具介绍

    Linux操作系统的压缩.解压缩工具介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.compress/uncompress命令常用参数 Linux compress命令: ...