3529: [Sdoi2014]数表 【莫比乌斯反演】
2016-03-02 14:19
295 查看
**
**
**
**
**
**
1 < =N.m < =10^5 , 1 < =Q < =2×10^4
**
Round 1 Day 1
**
http://pan.baidu.com/s/1c1vEolq
/article/1560366.html
发现写博客是个好习惯QAQ 找东西也好找……还能混多长时间就写多长时间吧……
莫比乌斯反演QAQ
推荐一篇不错的博客 里面有几道gcd的题目
https://oi.abcdabcd987.com/eight-gcd-problems/
**
——选择了远方,只顾风雨兼程
Description
**有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为 能同时整除i和j的所有自然数之和。给定a,计算数表中不大于a的数之和。
**
Input
**输入包含多组数据。 输入的第一行一个整数Q表示测试点内的数据组数,接下来Q行,每行三个整数n,m,a(|a| < =10^9)描述一组数据。
**
Output
**对每组数据,输出一行一个整数,表示答案模2^31的值。
**
Sample Input
**2 4 4 3 10 10 5
**
Sample Output
**20 148
**
HINT
**1 < =N.m < =10^5 , 1 < =Q < =2×10^4
**
Source
**Round 1 Day 1
**
Solution
**http://pan.baidu.com/s/1c1vEolq
/article/1560366.html
发现写博客是个好习惯QAQ 找东西也好找……还能混多长时间就写多长时间吧……
莫比乌斯反演QAQ
推荐一篇不错的博客 里面有几道gcd的题目
https://oi.abcdabcd987.com/eight-gcd-problems/
**
Code
**#include <bits/stdc++.h> using namespace std; const int maxn=1e5+10; struct data{int n,m,a,id;}q[maxn],f[maxn]; int d[maxn],mx; int ask(int x){int ans=0;while(x)ans+=d[x],x-=(x&-x);return ans;} void update(int x,int w) { while(x<=mx) d[x]+=w,x+=(x&-x); } int res[maxn]; bool vis[maxn]; int pri[maxn],u[maxn]; void ini(int n) { u[1]=1; for(int i=2;i<n;i++) { if(!vis[i]){pri[++pri[0]]=i,u[i]=-1;} for(int j=1;j<=pri[0]&&i*pri[j]<n;j++) { vis[pri[j]*i]=1; if(i%pri[j]==0){u[i*pri[j]]=0;break;} else u[pri[j]*i]=-u[i]; } } memset(f,0,sizeof(f)); for(int i=1;i<n;i++) for(int j=i;j<n;j+=i) f[j].a+=i; for(int i=1;i<n;i++)f[i].id=i; } bool cmp(data x,data y){return x.a<y.a;}; int _find(int a) { int l=1,r=mx,ans; while(l<=r) { int mid=(l+r)>>1; if(f[mid].a<=a)ans=mid,l=mid+1; else r=mid-1; } return ans; } int main() { int T; scanf("%d",&T); for(int i=1;i<=T;i++) scanf("%d%d%d",&q[i].n,&q[i].m,&q[i].a),q[i].id=i; for(int i=1;i<=T;i++){if(q[i].n>q[i].m)swap(q[i].n,q[i].m);mx=max(mx,q[i].n);} ini(mx+1); sort(q+1,q+1+T,cmp);sort(f+1,f+1+mx,cmp); int lasta=1; for(int i=1;i<=T;i++) { int nxta=_find(q[i].a); for(int j=lasta;j<=nxta;j++) for(int k=f[j].id;k<=mx;k+=f[j].id) update(k,f[j].a*u[k/f[j].id]); for(int j=1,k;j<=q[i].n;j=k+1) { k=min(q[i].n/(q[i].n/j),q[i].m/(q[i].m/j)); res[q[i].id]+=(ask(k)-ask(j-1))*(q[i].n/j)*(q[i].m/j); } lasta=nxta+1; } for(int i=1;i<=T;i++)printf("%d\n",res[i]&0x7fffffff); return 0; }
——选择了远方,只顾风雨兼程
相关文章推荐
- 将u盘格式化为EXFAT
- Android代码优化小技巧
- [转]AngularJS fixed header scrollable table directive
- spring学习。理解一些思想。记住一些常规用法
- bzoj3143 游走
- leetcode - Restore IP Addresses
- Android--Logcat
- %02d的使用
- 目标文件中符号表的符号类型
- 【精】进阶教程!让视觉设计变得高效+有说服力的4个步骤
- this class is not key value coding-compliant for the key buttonPressed.' 错误解决方式
- java 语言中的重载 跟 重写的区别
- Sapphire算法:GC Without Stop the World(上)
- Unity3d优化
- SHDP--Working With HBase (二)之HBase JDBC驱动Phoenix与SpringJDBCTemplate的集成
- 获得服务器硬件信息(CPUID、硬盘号、主板序列号、IP地址等)
- NoSQl简介(转)
- linux的定时任务--crontab
- Linux之platform设备驱动
- Postgres-XL9.5集群安装与配置