BZOJ3529: [Sdoi2014]数表(莫比乌斯反演 树状数组)
题意
Sol
首先不考虑\(a\)的限制
我们要求的是
\]
用常规的套路可以化到这个形式
\]
设\(kd = T\)
那么
\(\sum_{T = 1}^n \left\lfloor \frac{n}{T} \right\rfloor \left\lfloor \frac{m}{T} \right\rfloor \sum_{d \ | T} \sigma(d) \mu(\frac{T}{d})\)
然后按照套路筛出后面的卷积。
但是现在有\(a\)的限制了。。
那么可以直接离线之后树状数组维护一下。
时间复杂度:\(O(T\sqrt{n}logn)\)
约数个数和用埃氏筛两行就筛出来了
#include<bits/stdc++.h>
#define chmax(a, b) (a = (a > b ? a : b))
#define chmin(a, b) (a = (a < b ? a : b))
//#define int long long
using namespace std;
const int MAXN = 3e5 + 10;
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int T, mx, mu[MAXN], phi[MAXN], prime[MAXN], tot, vis[MAXN], si[MAXN], out[MAXN], p[MAXN];
struct Query{
int N, M, a, id;
bool operator < (const Query &rhs) const {
return a < rhs.a;
}
}q[MAXN];
int comp(const Query &a, const Query &b) {
return a.id < b.id;
}
int comp2(const int &a, const int &b) {
return si[a] < si[b];
}
void Get(int N) {
for(int i = 1; i <= N; i++)
for(int j = i; j <= N; j += i) si[j] += i;
vis[1] = 1; mu[1] = 1;
for(int i = 2; i <= N; i++) {
if(!vis[i]) prime[++tot] = i, mu[i] = -1;
for(int j = 1; j <= tot && i * prime[j] <= N; j++) {
vis[i * prime[j]] = 1;
if(!(i % prime[j])) {mu[i * prime[j]] = 0; break;}
else mu[i * prime[j]] = -mu[i];
}
}
}
#define lb(x) (x & (-x))
int Tr[MAXN];
void Add(int x, int val) {
while(x <= mx) Tr[x] += val, x += lb(x);
}
int Sum(int x) {
int ans = 0;
while(x) ans += Tr[x], x -= lb(x);
return ans;
}
int solve(int n, int m) {
int rt = 0, las = 0, now;
for(int i = 1, nxt; i <= n; i = nxt + 1) {
nxt = min(m / (m / i), n / (n / i));
now = Sum(nxt);
rt += (n / i) * (m / i) * (now - las);
las = now;
}
return rt;
}
signed main() {
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;
if(q[i].N > q[i].M) swap(q[i].N, q[i].M);;
chmax(mx, q[i].N);
}
Get(mx);
for(int i = 1; i <= mx; i++) p[i] = i;
sort(p + 1, p + mx + 1, comp2);
sort(q + 1, q + T + 1);
for(int t = 1, d = 1; t <= T; t++) {
for(; d <= mx && si[p[d]] <= q[t].a; d++) {
for(int k = p[d]; k <= mx; k += p[d]) {
if(!mu[k / p[d]]) continue;
Add(k, si[p[d]] * mu[k / p[d]]);
}
}
out[q[t].id] = solve(q[t].N, q[t].M);
}
for(int i = 1; i <= T; i++)
printf("%d\n", out[i] < 0 ? out[i] + 2147483648 : out[i]);
//printf("%d\n", out[i] <);
return 0;
}
BZOJ3529: [Sdoi2014]数表(莫比乌斯反演 树状数组)的更多相关文章
- 【BZOJ3529】[Sdoi2014]数表 莫比乌斯反演+树状数组
[BZOJ3529][Sdoi2014]数表 Description 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为能同时整除i和 ...
- BZOJ 3259 [Sdoi2014]数表 (莫比乌斯反演 + 树状数组)
3529: [Sdoi2014]数表 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2321 Solved: 1187[Submit][Status ...
- BZOJ 3529: [Sdoi2014]数表 [莫比乌斯反演 树状数组]
3529: [Sdoi2014]数表 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1399 Solved: 694[Submit][Status] ...
- BZOJ 3529 [Sdoi2014]数表 (莫比乌斯反演+树状数组+离线)
题目大意:有一张$n*m$的数表,第$i$行第$j$列的数是同时能整除$i,j$的所有数之和,求数表内所有不大于A的数之和 先是看错题了...接着看对题了发现不会做了...刚了大半个下午无果 看了Po ...
- 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 ...
- luogu3312 [SDOI2014]数表 (莫比乌斯反演+树状数组)
link \(\sum_{i=1}^n\sum_{j=1}^m[s(\gcd(i,j))\le a]s(\gcd(i,j))\) \(=\sum_{p=1}^ns(p)[s(p)\le a]\sum_ ...
- 【BZOJ3529】【莫比乌斯反演 + 树状数组】[Sdoi2014]数表
Description 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为 能同时整除i和j的所有自然数之和.给定a,计算数表中不大于 ...
- bzoj 3529 数表 莫比乌斯反演+树状数组
题目大意: 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为能同时整除i和j的所有自然数之和.给定a,计算数表中不大于a的数之和. ...
- 【BZOJ3529】【SDOI2014】数表 (莫比乌斯反演+树状数组)
传送门 Description 有一张$n\times m$的数表,其第$i$行第$j$列 $(1≤i≤n,1≤j≤m)$ 的数值为能同时整除$i$和$j$的所有自然数之和.现在给定$a$,计算数表中 ...
随机推荐
- JSP入门之自定义标签
第二部分简单讲解:主要讲解el表达式,核心标签库.本章主要讲解:自定义标签库:404页面,505页面,错误页面配置方法 全部代码下载:链接 1.JSP自定义标签: 自定义标签是用户定义的JSP语言元素 ...
- iOS --UIScrollView的学习(三)自动轮播
1.前面两章讲的都是基本的用法,这次讲一下比较重要的功能分页和自动播放 2.UIPageControl--分页 2.1只要将UIScrollView的pageEnabled属性设置为YES,UIScr ...
- 在eclipse中,用maven创建web项目
备注:该文档是之前学习时,根据网上其他童鞋的经验自己测试后梳理,如有侵权,请勿怪,感谢! 1.在eclipse中用maven创建项目,右键new>>Maven Project 2.点击ne ...
- 关于在JS中AJAX导致跨域问题的解决
在部署一个原声的前端项目的时候,请求该服务器后端接口时发现出现了CORS跨域的问题,但是服务端已经做了同源策略的兼容,常见问题,遂记录. 报错信息: XMLHttpRequest cannot loa ...
- ubuntu下安装ffmpeg
sudo add-apt-repository ppa:kirillshkrogalev/ffmpeg-next sudo apt-get update sudo apt-get install ff ...
- Unity脚本生命周期与执行顺序
文章目录 脚本生命周期 MonoBehavior生命周期图 脚本执行顺序 自定义执行顺序 在Unity中,脚本可以理解为附加在游戏对象上的用于定义游戏对象行为的指令代码.必须绑定在游戏对象上才能开始它 ...
- android:activity知识点
一.活动流程 1.创建活动 public class firstActivity extends Activity{} 2.创建布局 新建first_layout.xml文件 3.注册活动 在andr ...
- Android各版本及API对应关系,持续更新!
以下是Android的各个版本与API的对应关系图标,便于查阅,会持续更新 API等级 Android版本号 Android版本名称 对应支持包 API等级1: Android 1.0 API ...
- Java集合类中的Iterator和ListIterator的区别
注意:内容来自网络他人文章! 最近看到集合类,知道凡是实现了Collection接口的集合类,都有一个Iterator方法,用于返回一个实现了Iterator接口的对象,用于遍历集合:(Iterato ...
- Java学习之路(五):常见的对象操作
Object对象 我们先来介绍一下API API(Application Programming Interface):应用程序编程接口 Java API 就是Java提供给我们使用的类,这些类将底层 ...