LINK:NOI2016循环之美

这道题是 给出n m k 求出\(1\leq i\leq n,1\leq j\leq m\) \(\frac{i}{j}\)在k进制下是一个纯循环的。

由于数值相同的分数不能记录 所以 \((i,j)==1\) 对于是一个纯循环的数我们先从最熟悉的10进制下说起。

可以发现\(\frac{1}{7},\frac{1}{13}\)等等都是纯循环的 而\(\frac{1}{6},\frac{1}{4}\)等等非纯循环。

于是可以发现 当j和10互质的时候此时是纯循环。不妨证明这一点。

当 j和10互质的时候 可以发现j和10没有共有的因子所以\(10^w\)在mod j的情况下是有循环的。这类似于完全剩余系。

当j和10不互质 时 显然可以发现 前半部分时非循环后半部分由于因数被消掉之后 剩下和10互质的数 所以后半部分时一个循环 但此时已经不满足条件了。

从10 我们发现一个有意思的时候 那就是我们好像可以推广到K进制 在K进制下也是一个纯循环的数当且仅当 j在K进制下和K互质。

举个例子 在5进制下 \(\frac{3}{4}\) 4和5 互质 而且你可以自己手算一下这个结果是0.33333333 在5进制下。

说明我们假设成立。(考场上还是要靠猜的。

但是这样求还是很困难 因为j在K进制下和K互质 nm暴力之外还要把 j转成K进制 还要再求gcd 这着实优化不了。

O(m)暴力我们都T掉了。

考虑两个数字互质有 (a,b)==1 在K进制下 \((...+p_1k^1+p_0k^0,...+b_1k^1+b_0k^0)\)这个东西gcd会是多少呢

我猜测是1 /cy 通过不断的打表发现是正确的。于是不考虑证明我们得到这样的一个式子。

题目要求的是 \(\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}[(i,j)=1][(j,k)=1]\)

随便变型一下:\(\sum\limits_{i=1}^{n}\sum\limits_{j=1,且(j,k)=1}^{m}\sum_{d|i,d|j}\mu(d)\)

\(\to \sum_{d=1}^{n}\mu(d)\frac{n}{d}\sum_{j=1}^{\frac{m}{d}}[(jd,k)=1]\)

你发现都推到这里了 还是很难求。

但是到了这个地方再把互质的条件进行反演会非常繁杂。

一般到这个时候直接整除分块。所以我们只需要考虑 \(\sum_{d=1}^{n}[(d,k)=1]\mu(d)\)这个东西和\(\sum_{j=1}^{\frac{m}{d}}[(j,k)=1]\)的前缀和即可。

先考虑后面 设函数g(x)表示 \(\sum_{i=1}{x}[(i,k)=1]\) 那么\(g(x)=\frac{x}{k}g(k)+g(x\mod k)\)

那么预处理g函数很简单 O(k)枚举暴力算即可。

考虑前面那个东西的前缀和 \(S(n,k)=\sum_{d=1}^{n}\mu(d)[(d,k)=1]\)

这个时候没有什么办法化简了 而直接求是复杂度很高。

反演一下 \(S(n,k)=\sum_{d=1}^{n}\mu(d)\sum_{x|d,x|k}\mu(x)\)

\(S(n,k)=\sum_{x|k}\mu(x)\sum_{d=1}{\frac{n}{x}}\mu(xd)\)

这个时候 看起来没办法化简了 但是其实我们观察一下\(\mu(xd)\) \((x,d)\neq 1\)时 对答案才有贡献。

由积性函数可得 \(S(n,k)=\sum_{x|k}\mu(x)\sum_{d=1}{\frac{n}{x}}\mu(d)\mu(x)[(x,d)=1]\)

根据我们S函数的定义可得 \(\sum_{d=1}{\frac{n}{x}}\mu(d)\mu(x)[(x,d)=1]\)

所以总式子为\(S(n,k)=\sum_{x|k}\mu(x)^2 S(\frac{n}{x},d)\)

所以这个S函数可以递归的算出来 我们利用map存起来来加快速度 对于mu(x)==0的可以不算。

显然递归边界为x==1 这个时候观察原式 其实式求\(\mu(x)\)的前缀和。

所以我们杜教筛一下。这样就可以求了。注意求S的时候也要开map来加速 还需要判断一下边界什么的。

复杂度?关于S的求出我并不会 分析复杂度。

const int MAXN=5000010,maxn=2010;
int n,m,k,top,maxx=5000000;
int mu[MAXN],p[MAXN],v[MAXN],g[maxn],w[MAXN];
inline int gcd(int a,int b){return b?gcd(b,a%b):a;}
map<int,int>H;map<pii,ll>s;
inline void prepare()
{
rep(1,k,i){g[i]+=g[i-1];if(gcd(i,k)==1)++g[i];}
mu[1]=1;
rep(2,maxx,i)
{
if(!v[i])
{
p[++top]=v[i]=i;
mu[i]=-1;
}
rep(1,top,j)
{
if(maxx/i<p[j])break;
v[i*p[j]]=p[j];
if(v[i]==p[j])break;
mu[i*p[j]]=-mu[i];
}
}
rep(1,maxx,i)w[i]+=w[i-1]+mu[i];
}
inline int djs(int x)
{
if(x<=maxx)return w[x];
if(H.find(x)!=H.end())return H[x];
int ans=1;
int w,ww;
for(int i=2;i<=x;i=ww+1)
{
w=x/i;ww=x/w;
ans-=(ww-i+1)*djs(w);
}
H[x]=ans;return ans;
}
inline ll S(int n,int k)
{
if(k==1)return djs(n);
if(n==1)return 1;
if(!n)return 0;
if(s.find(mk(n,k))!=s.end())return s[mk(n,k)];
ll ans=0;
for(int i=1;i*i<=k;++i)
{
if(k%i==0)
{
if(mu[i])ans=ans+S(n/i,i);
if(mu[k/i]&&i*i!=k)ans=ans+S(n/(k/i),k/i);
}
}
s[mk(n,k)]=ans;
return ans;
}
inline ll G(ll x){return x/k*g[k]+g[x%k];}
int main()
{
//freopen("1.in","r",stdin);
get(n);get(m);get(k);
prepare();
int w1,w2,ww;
ll ans=0;
int cc=min(n,m);
for(RE int i=1;i<=cc;i=ww+1)
{
w1=n/i;w2=m/i;
ww=min(n/w1,m/w2);
ans=ans+w1*(S(ww,k)-S(i-1,k))*G(w2);
}
printf("%lld\n",ans);
return 0;
}

luogu 1587 [NOI2016]循环之美的更多相关文章

  1. luogu P1587 [NOI2016]循环之美

    传送门 首先要知道什么样的数才是"纯循环数".打表可以发现,这样的数当且仅当分母和\(k\)互质,这是因为,首先考虑除法过程,每次先给当前余数\(*k\),然后对分母做带余除法,那 ...

  2. [UOJ#221][BZOJ4652][Noi2016]循环之美

    [UOJ#221][BZOJ4652][Noi2016]循环之美 试题描述 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 k 进制下,一个数的小数部 ...

  3. bzoj4652 [Noi2016]循环之美

    Description 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在k进制下,一个数的小数部分是纯循环的,那么它就是美的.现在,牛牛想知道:对于已知 ...

  4. [NOI2016]循环之美

    Description 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 k  进制下,一个数的小数部分是纯循环的,那么它就是美的.现在,牛牛想知道:对 ...

  5. BZOJ4652: [Noi2016]循环之美(莫比乌斯反演,杜教筛)

    Description 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 k  进制下,一个数的小数部分是纯循环的,那么它就是美的.现在,牛牛想知道:对 ...

  6. BZOJ4652 [Noi2016]循环之美 【数论 + 莫比乌斯反演 + 杜教筛】

    题目链接 BZOJ 题解 orz 此题太优美了 我们令\(\frac{x}{y}\)为最简分数,则\(x \perp y\)即,\(gcd(x,y) = 1\) 先不管\(k\)进制,我们知道\(10 ...

  7. 洛谷P1587 [NOI2016]循环之美

    传送门 不会,先坑着 https://kelin.blog.luogu.org/solution-p1587 //minamoto #include<cstdio> #include< ...

  8. 题解 P1587 【[NOI2016]循环之美】

    知识点:莫比乌斯反演 积性函数 杜教筛 废话前言: 我是古明地恋,写这篇题解的人已经被我 请各位读者自行无视搞事的恋恋带有删除线的内容,谢谢茄子. 这道题目本身并不难,但是公式推导/代码过程中具有迷惑 ...

  9. BZOJ4652 NOI2016循环之美(莫比乌斯反演+杜教筛)

    因为要求数值不同,不妨设gcd(x,y)=1.由提示可以知道,x/y是纯循环小数的充要条件是x·klen=x(mod y).因为x和y互质,两边同除x,得klen=1(mod y).那么当且仅当k和y ...

随机推荐

  1. 点分治模板 POJ 1741

    #include<cstdio> #include<cstring> #include<algorithm> using namespace std; const ...

  2. Windows下的Linux系统

    强调!!!必须是Windows专业版!!! 一.安装运行过程 第一步:打开开发人员模式 第二步:进入 '控制面板 '--'程序'--'启用的Windows功能'--勾选Linux子系统(根据提示进行重 ...

  3. Github和Azure DevOps的代码同步

    [前言]Github和Azure DevOps都提供了Git代码库功能,那么有没有办法将两边的代码库进行同步呢,答案是肯定的.这里的操作我都是用Azure DevOps的Pipelines功能来完成的 ...

  4. SpringBoot+Mybatis一级缓存和二级缓存详解

    本文主要介绍在SpringBoot项目中如何使用Mybatis的一级.二级缓存,为了演示方便,本文的数据库采用H2内存数据库,数据库连接池默认使用SpringBoot2.X自带的hikariCP. 正 ...

  5. [JAVA]解决不同浏览器下载附件的中文名乱码问题

    附件下载时,遇到中文附件名的兼容性问题,firefox.chrome.ie三个派系不兼容,通过分析整理,总结出处理该问题的办法,记录如下: 1.文件名编码 服务器默认使用的是ISO8859-1,而我们 ...

  6. 【题解】uva1104 chips challenge

    原题传送门 题目分析 给定一张n*n的芯片. '.'表示该格子可以放一个零件. 'C'表示该格子已经放了一个零件(不能拆下). '/'表示该格子不能放零件. 要求在芯片的现有基础上,放置尽可能多的零件 ...

  7. Github Actions简单部署一个vue/react项目

    大体介绍 本文对github actions部署前端项目做一个简单的总结,总体来说,我感觉用它想要部署一个前端项目,可以说非常简单,简单得令人震惊

  8. python 装饰器(一):装饰器基础(一)装饰器形式,何时执行

    简介 装饰器是可调用的对象,其参数是另一个函数(被装饰的函数). 装饰器可能会处理被装饰的函数,然后把它返回,或者将其替换成另一个函数或可调用对象. 形式 假如有个名为 decorate 的装饰器: ...

  9. PHP 反序列化漏洞入门学习笔记

    参考文章: PHP反序列化漏洞入门 easy_serialize_php wp 实战经验丨PHP反序列化漏洞总结 PHP Session 序列化及反序列化处理器设置使用不当带来的安全隐患 利用 pha ...

  10. Oracle DataGuard主备切换(switchover)

    Oracle DataGuard主备切换可以使用传统的手动命令切换,也可以使用dgmgr切换,本文记录手动切换. (一)将主库切换为物理备库 STEP1:查看主库状态 SQL> SELECT O ...