博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj3994: [SDOI2015]约数个数和
阅读量:5057 次
发布时间:2019-06-12

本文共 1374 字,大约阅读时间需要 4 分钟。

一个下午摸不到键盘系列。

看题解推柿子要爆炸。。

推到吐了,看到最后又变成约数个数心里一万只cnm飞过。。所以在电脑上就不重写了。

觉得这一辈子都不会忘记约数个数公式了。。

有(si)用(ji)的东(gong)西(shi):

d(nm)= sigema(x|n) sigema(y|m) [gcd(x,y)==1]

sigema(x|n) u(x)=[n==1]  比如 sigema(x|gcd(a,b))u(x)=[gcd(a,b)==1]  在这里上限就是min(a的上限,b的上限)

n的约数个数也等于这个:sigema(1~n)i  (n/i) (向下整除)

然后学会了线筛约数。

#include
#include
#include
#include
#include
#include
using namespace std;typedef long long LL;int pr,prime[51000];bool v[51000];LL u[51000],yue[51000],cs[51000];void f__klajiti(){ pr=0; memset(v,true,sizeof(v));v[1]=false; u[1]=1;yue[1]=1; for(int i=2;i<=50000;i++) { if(v[i]==true) { prime[++pr]=i; u[i]=-1; yue[i]=2; cs[i]=1; } for(int j=1;j<=pr&&i*prime[j]<=50000;j++) { v[i*prime[j]]=false; if(i%prime[j]==0) { u[i*prime[j]]=0; yue[i*prime[j]]=yue[i]/(cs[i]+1)*(cs[i]+2); cs[i*prime[j]]=cs[i]+1; break; } u[i*prime[j]]=-u[i]; yue[i*prime[j]]=yue[i]*2; cs[i*prime[j]]=1; } u[i]+=u[i-1]; yue[i]+=yue[i-1]; }}int main(){ f__klajiti(); int T_TzzLmy; scanf("%d",&T_TzzLmy); while(T_TzzLmy--) { int n,m; scanf("%d%d",&n,&m); if(n>m)swap(n,m); LL LJHHN=0;int last=0; for(int d=1;d<=min(n,m);d=last+1) { last=min(n/(n/d),m/(m/d)); LJHHN+=(u[last]-u[d-1])*yue[n/d]*yue[m/d]; } printf("%lld\n",LJHHN); } return 0;}

 

转载于:https://www.cnblogs.com/AKCqhzdy/p/8625181.html

你可能感兴趣的文章
一个mysql主从复制的配置案例
查看>>
大数据学习系列(8)-- WordCount+Block+Split+Shuffle+Map+Reduce技术详解
查看>>
【AS3代码】播放FLV视频流的三步骤!
查看>>
枚举的使用
查看>>
luogu4849 寻找宝藏 (cdq分治+dp)
查看>>
日志框架--(一)基础篇
查看>>
关于源程序到可运行程序的过程
查看>>
转载:mysql数据库密码忘记找回方法
查看>>
scratch少儿编程第一季——06、人在江湖混,没有背景怎么行。
查看>>
【贪心+DFS】D. Field expansion
查看>>
C# Async与Await的使用
查看>>
Mysql性能调优
查看>>
iOS基础-UIKit框架-多控制器管理-实例:qq界面框架
查看>>
IOS-每个程序员的编程之路上都应该看这11本书
查看>>
自定义tabbar(纯代码)
查看>>
小程序底部导航栏
查看>>
ibatis学习笔记
查看>>
18-ES6(1)
查看>>
poj1611 简单并查集
查看>>
Ubuntu 14.04下安装CUDA8.0
查看>>