bzoj 3529 数表 莫比乌斯反演+树状数组
题目大意:
有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为
能同时整除i和j的所有自然数之和。给定a,计算数表中不大于a的数之和。
http://wenku.baidu.com/link?url=1zHluup-GXHdByoQXhMRwRu22Uu15y4DztIr1_hKVxjHJmuLQF4_01UQhLEOR7RJIpsGyfD_5fXrx9DE7sY6JeukaNUY83In097GjUOmZ7K
ppt课件中讲的很仔细了
#include <bits/stdc++.h> using namespace std;
#define N 100000
#define ll long long
#define lowbit(x) x&(-x)
typedef pair<int , int> pii;
int sum[N+] , mu[N+] , prime[N+] , tot;
bool check[N+];
pii f[N+]; void get_mu()
{
mu[] = ;
for(int i= ; i<=N ; i++) f[i].first= , f[i].second = i;
for(int i= ; i<=N ; i++){
if(!check[i]){
mu[i] = -;
prime[tot++] = i;
}
for(int j= ; j<tot ; j++){
if((ll)prime[j]*i>N) break;
check[i*prime[j]] = true;
if(i%prime[j]){
mu[i*prime[j]] = -mu[i];
}else break;
}
}
for(int i= ; i<=N ; i++)
for(int j=i ; j<=N ; j+=i)
f[j].first += i;
} struct Query{
int n , m , a , id;
void in(int i){scanf("%d%d%d" , &n , &m , &a) ; id=i;}
void reset(){if(n>m) swap(n,m);}
bool operator<(const Query &m)const {
return a<m.a;
}
}qu[N]; int mxl , Q , ans[N]; void add(int x , int v)
{
for(int i=x ; i<=mxl ; i+=lowbit(i)) sum[i]+=v;
} int query(int x)
{
int ret = ;
for(int i=x ; i> ; i-=lowbit(i)) ret += sum[i];
return ret;
} int find(int n , int m)
{
int ret = , last;
for(int i= ; i<=n ; i=last+){
last = min(n/(n/i) , m/(m/i));
ret += n/i*(m/i)*(query(last)-query(i-));
// cout<<n<<" "<<m<<" "<<ret<<" "<<query(last)<<" "<<query(i-1)<<endl;
}
return ret&(0x7fffffff);
} void solve()
{
memset(sum , , sizeof(sum));
int index = , cnt=;
for(int i= ; i<=Q ; i++){
while(f[index].first<=qu[i].a&&cnt<mxl){
for(int j=f[index].second , k= ; j<=mxl ; j+=f[index].second ,k++){
// cout<<index<<" "<<f[index].second<< " "<<f[index].first<<" "<<k<<" "<<mu[k]<<endl;
add(j , f[index].first*mu[k]);
}
index++;
if(f[index].second<=mxl) cnt++;
}
ans[qu[i].id] = find(qu[i].n , qu[i].m);
}
for(int i= ; i<=Q ; i++) printf("%d\n" , ans[i]);
} int main()
{
//freopen("in.txt" , "r" , stdin);
get_mu();
sort(f+ , f+N+);
while(~scanf("%d" , &Q)){
mxl = ;
for(int i= ; i<=Q ; i++) {
qu[i].in(i) , qu[i].reset();
mxl = max(mxl , qu[i].n);
}
sort(qu+ , qu+Q+);
solve();
}
return ;
}
bzoj 3529 数表 莫比乌斯反演+树状数组的更多相关文章
- 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 ...
- BZOJ 3259 [Sdoi2014]数表 (莫比乌斯反演 + 树状数组)
3529: [Sdoi2014]数表 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2321 Solved: 1187[Submit][Status ...
- 【BZOJ3529】[Sdoi2014]数表 莫比乌斯反演+树状数组
[BZOJ3529][Sdoi2014]数表 Description 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为能同时整除i和 ...
- BZOJ3529: [Sdoi2014]数表(莫比乌斯反演 树状数组)
题意 题目链接 Sol 首先不考虑\(a\)的限制 我们要求的是 \[\sum_{i = 1}^n \sum_{j = 1}^m \sigma(gcd(i, j))\] 用常规的套路可以化到这个形式 ...
- 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_[Sdoi2014]数表_莫比乌斯反演+树状数组
Description 有一张 n×m 的数表,其第 i 行第 j 列(1 <= i <= n, 1 <= j <= m)的数值为 能同时整除 i 和 j 的所有自然数之和.给 ...
随机推荐
- Handler详解系列(四)——利用Handler在主线程与子线程之间互发消息,handler详解
MainActivity如下: package cc.c; import android.app.Activity; import android.os.Bundle; import android. ...
- 在Eclipse中设置Java类上面的注释(包含作者、日期等)
希望在Eclipse中,让Java类上面的注释像下面这样,改如何设置呢? 在Eclipse中,点击菜单中的Window-->Preferences,打开如下窗口:
- innodb_fast_shutdown中值为1或者2的区别是?
innodb_fast_shutdown=0 , 1 , 2时的意思分别是 0 把buffer pool中的脏页刷到磁盘和合并insert buffer,当然包括redo log也会写到磁盘中. 2 ...
- 设置pictureBox的边框颜色
private void pictureBox2_Paint(object sender, PaintEventArgs e) { PictureBox p = (PictureBox)sender; ...
- python 练习 9
#!/usr/bin/python # -*- coding: UTF-8 -*- for i in range(1,5): for j in range(1,5): for k in range(1 ...
- Gas Station [LeetCode]
There are N gas stations along a circular route, where the amount of gas at station i is gas[i]. You ...
- webservice方法内用了session,asp.net调用时注意问题
可搜索相关:ASP.NET WebService 中使用 ASP.NET_SessionId 当前问题是:我们写了WebService给客户调用,第一个方法是登陆,传入用户名和密码,成功后在Webse ...
- 为大家分享一个 Ajax Loading —— spin.js(转)
原文地址:http://www.cnblogs.com/lxblog/p/3425599.html 我们在做Ajax 异步请求的时候,一般都会利用一个动态的 Gif 小图片来制作一个Ajax Load ...
- Python输出内容的三种方式:print输出 python脚本执行 linux直接执行
1. 在linux中安装python后,在linux命令行中输入python即可切换到Python命令行下 退出python命令行的命令: 老版本:ctrl+D 新版本:quit();或exit() ...
- CSS垂直居中对齐
用CSS有多种方法实现垂直居中对齐.如果已知外部div的高度,不管是否知道内部div的高度,垂直居中实现起来很简单,但如果内部div高度是变量,如文字,垂直居中实现起来就比较复杂了,很可能需要使用ha ...