题面

题解

不管$a$的限制

我们要求的东西是:($\sigma(x)$是$x$的约数个数和)

$ \sum_{i=1}^n\sum_{j=1}^m\sigma(gcd(i,j)) $

设$f(x)=\sigma(x)$,则我们可以找到一个$g$使得$f=1*g$,那么$g=\mu*f$

所以$g(x)=\sum_{d|x}\mu(d)\sigma(\frac xd)$

带入原式得:

$ \sum_{i=1}^n\sum_{j=1}^m\sigma(gcd(i,j)) \\ =\sum_{d=1}^n g(d)\left\lfloor\frac nd\right\rfloor \left\lfloor\frac md\right\rfloor \\ =\sum_{d=1}^n \left\lfloor\frac nd\right\rfloor \left\lfloor\frac md\right\rfloor \sum_{x|d}\mu(x)\sigma(\frac dx) $

我们可以筛出$g(x)$的值来$O(\sqrt n)$回答

但是现在有$a$的限制,就可以离线将询问排序,将$\sigma$排序,加入相对应的位置就可以了。

代码

#include<cstdio>
#include<cstring>
#include<cctype>
#include<climits>
#include<algorithm>
#define RG register
#define file(x) freopen(#x".in", "r", stdin);freopen(#x".out", "w", stdout);
#define clear(x, y) memset(x, y, sizeof(x)) inline int read()
{
int data = 0, w = 1; char ch = getchar();
while(ch != '-' && (!isdigit(ch))) ch = getchar();
if(ch == '-') w = -1, ch = getchar();
while(isdigit(ch)) data = data * 10 + (ch ^ 48), ch = getchar();
return data * w;
} const int maxn(100010);
bool not_prime[maxn];
int prime[maxn], cnt, n, T, ans[maxn];
int mu[maxn], sig[maxn], sumd[maxn], powd[maxn]; struct qry { int n, m, a, id; } q[maxn];
int p[maxn], c[maxn];
inline bool operator < (const qry &a, const qry &b) { return a.a < b.a; } void init(int N)
{
not_prime[1] = true; sig[1] = mu[1] = p[1] = 1;
for(RG int i = 2; i <= N; i++)
{
p[i] = i;
if(!not_prime[i]) prime[++cnt] = i, mu[i] = -1,
sig[i] = i + 1, sumd[i] = i + 1, powd[i] = i;
for(RG int j = 1; j <= cnt && i * prime[j] <= N; j++)
{
not_prime[i * prime[j]] = true;
if(i % prime[j])
{
mu[i * prime[j]] = -mu[i];
sig[i * prime[j]] = sig[i] * sig[prime[j]];
sumd[i * prime[j]] = prime[j] + 1;
powd[i * prime[j]] = prime[j];
}
else
{
powd[i * prime[j]] = powd[i] * prime[j];
sumd[i * prime[j]] = sumd[i] + powd[i * prime[j]];
sig[i * prime[j]] = sig[i] / sumd[i] * sumd[i * prime[j]];
break;
}
}
}
} inline bool cmp(int a, int b) { return sig[a] < sig[b]; }
void add(int x, int v) { while(x <= n) c[x] += v, x += x & -x; }
int query(int x) { int ans = 0; while(x) ans += c[x], x -= x & -x; return ans; }
int solve(int x, int y)
{
int now = 0, pre = 0, ans = 0;
for(RG int i = 1, j; i <= x; i = j + 1)
{
j = std::min(x / (x / i), y / (y / i));
now = query(j); ans += (x / i) * (y / i) * (now - pre);
pre = now;
}
return ans;
} int main()
{
T = read();
for(RG int i = 1; i <= T; i++)
{
q[i] = (qry) {read(), read(), read(), i};
if(q[i].n > q[i].m) std::swap(q[i].n, q[i].m);
n = std::max(n, q[i].n);
}
init(n); std::sort(q + 1, q + T + 1);
std::sort(p + 1, p + n + 1, cmp);
for(RG int i = 1, j = 1; i <= T; i++)
{
for(; j <= n && sig[p[j]] <= q[i].a; ++j)
for(RG int k = p[j]; k <= n; k += p[j])
if(mu[k / p[j]]) add(k, sig[p[j]] * mu[k / p[j]]);
ans[q[i].id] = solve(q[i].n, q[i].m);
}
for(RG int i = 1; i <= T; i++)
{
if(ans[i] < 0) ans[i] += INT_MAX, ++ans[i];
printf("%d\n", ans[i]);
}
return 0;
}

【SDOI2014】数表的更多相关文章

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

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

  2. 【BZOJ 3529】 [Sdoi2014]数表 (莫比乌斯+分块+离线+树状数组)

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

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

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

  4. 洛咕3312 [SDOI2014]数表

    洛咕3312 [SDOI2014]数表 终于独立写出一道题了...真tm开心(还是先写完题解在写的) 先无视a的限制,设\(f[i]\)表示i的约数之和 不妨设\(n<m\) \(Ans=\su ...

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

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

  6. 洛谷 P3312 [SDOI2014]数表 解题报告

    P3312 [SDOI2014]数表 题目描述 有一张\(N*M\)的数表,其第\(i\)行第\(j\)列(\(1\le i \le n\),\(1 \le j \le m\))的数值为能同时整除\( ...

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

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

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

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

  9. 洛谷P3312 - [SDOI2014]数表

    Portal Solution 共\(T(T\leq2\times10^4)\)组测试数据.给出\(n,m(n,m\leq10^5),a(a\leq10^9)\),求\[ \sum_{i=1}^n\s ...

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

    bzoj [SDOI2014]数表 莫比乌斯反演 BIT 链接 bzoj luogu loj 思路 \[ \sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}a*[f[ ...

随机推荐

  1. 简析Chrome和Webkit的渊源

    http://www.3lian.com/edu/2012/05-25/28803.html 互联网的浪潮从未停息,而用以网上冲浪的冲浪板也一直在变得愈加精良.自人们进入互联网时代以来,即已经发生了三 ...

  2. 【[IOI2005]Riv 河流】

    趁魏佬去英语演讲了,赶快%%%%%%%%%%%%%%魏佬 基本上是照着魏佬的代码写的 这其实还是一个树上背包 我们用\(dp[i][j][k]\)表示在以\(i\)为根的子树里,我们修建\(k\)个伐 ...

  3. windows下搭建nginx+php开发环境

    windows下搭建nginx+php开发环境 1.前言 windows下大多我们都是下载使用集成环境,但是本地已经存在一个集成环境,但不适合项目的需求.因此准备再自己搭建一个环境. 2.准备 工具: ...

  4. PAT——1020. 月饼

    月饼是中国人在中秋佳节时吃的一种传统食品,不同地区有许多不同风味的月饼.现给定所有种类月饼的库存量.总售价.以及市场的最大需求量,请你计算可以获得的最大收益是多少. 注意:销售时允许取出一部分库存.样 ...

  5. linux 常用进程使用命令

    查看进程占用pid ps aux | grep program_filter_word 杀死pid kill -

  6. SDN测量论文粗读(一)9.19

    UMON: Flexible and Fine Grained Traffic Monitoring in Open vSwitch 论文来源:CoNext 发表时间:2015 解决问题及所做贡献:现 ...

  7. 轻量ORM-SqlRepoEx (十三)最佳实践

    ORM-SqlRepoEx 是 .Net平台下兼容.NET Standard 2.0,一个实现以Lambda表达式转转换标准SQL语句,使用强类型操作数据的轻量级ORM工具,在减少魔法字串同时,通过灵 ...

  8. Xcode 创建 支持IOS4.3以上版本的应用的方法

    如果是Xcode 5的话步骤为 点击项目名称->Build Settings->搜索 Architectures 这个里面的原始的值是Standard architectures(armv ...

  9. PHP+jQuery实现双击修改table表格

    <td signs="name"> <input type="text" disabled="disabled" read ...

  10. echarts 报错问题 is null 或者未定义等问题

    我们在使用echarts的时候会出现is null或者未定义等报错提示,但是却无从下手的情况. 其一,我们是完全按照echarts的官方文档来添加的js文件:其二,在对使用option时候的配置是按照 ...