前面部分比较简单,就是无脑化式子,简单点讲好了。

首先肯定在\((x,y)=1\)时才考虑这个分数,要求纯循环的话,不妨猜猜结论,就是y必须和K互质。所以答案是\(\sum_{i=1}^n \sum_{j=1}^m [(i,j)=1] [(j,k)=1]\)。

然后用 \([(i,j)=1]=\sum_{d|i,j} \mu(d)\)大力化一化,很快就会得到:

\[\sum_{d=1}^{min(n,m)} \mu(d) \frac{n}{d} \sum_{d|j,j\le m}[(j,k)=1]
\]
\[=\sum_{d=1}^{min(n,m)} \mu(d) [(d,k)=1] \frac{n}{d} \sum_{j=1}^{\frac{m}{d}}[(j,k)=1]
\]

令后面那一坨\(\sum_{j=1}^{\frac{m}{d}}[(j,k)=1]=f(\frac{m}{d})\),它可以快速计算:

\[f(x)=\sum_{j=1}^x [(j,K)=1]
\]
\[=\sum_{j=1}^x \sum_{g|j,k} \mu(g)
\]
\[=\sum_{g|k}\mu(g) \sum_{g|j} 1
\]
\[=\sum_{g|k}\mu(g) \frac{x}{g}
\]

可以\(O(\sqrt k)\)计算。

回到原式

\[\sum_{d=1}^{min(n,m)} \mu(d) [(d,k)=1] \frac{n}{d} f(\frac{m}{d})
\]

这个显然可以分块吧,预处理一下\(\sum_{d=1}^{min(n,m)} \mu(d)[(d,k)=1]\)的前缀和就可以\(O(\sqrt n *\sqrt k)\)算答案了,因为是gcd的log,预处理做到2e7都不虚。

然后就有84分了。

考虑快速求\(F(k,x)=\sum_{d=1}^x \mu(d)*[(d,k)==1]\),同样拆后面的gcd。

\[F(k,x) =\sum_{d=1}^x \mu(d)*[(d,k)==1]
\]
\[=\sum_{d=1}^x \mu(d) \sum_{g|k,d} \mu(g)
\]
\[=\sum_{g|k} \mu(g) \sum_{g|d} \mu(d)
\]
\[=\sum_{g|k} \mu(g) \sum_{T=1}^{\frac{x}{g}} \mu(T*g)
\]

然后由于当\((T,g)\ne 1\)时\(\mu(T*g)\)显然=0。

\[=\sum_{g|k} \mu(g) \sum_{T=1}^{\frac{x}{g}} [(T,g)==1]*\mu(T)*\mu(g)
\]
\[=\sum_{g|k} \mu^2(g) \sum_{T=1}^{\frac{x}{g}} \mu(T)*[(T,g)==1]
\]
\[=\sum_{g|k} \mu^2(g) F(g,\frac{x}{g})
\]

然后递归算,顺便记忆化一下,另外当k=1时直接返回\(\sum_{i=1}^x \mu(i)\),因此要杜教筛预处理。

\(F(k,i)\)可以预处理一下\(k=K\)时x较小的若干项,会加快速度。

我根本不会算这个的复杂度,想到这后就直接去写了,极限数据一下就跑出来了就交了,别问我复杂度是多少,我不知道。复杂度应该和杜教筛差不多吧(如果对g讨论一下在x的\(\sqrt x\)段中的哪一段,这一段的k的约数统一计算的话)。

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<cmath>
#include<vector>
#include<map>
#define pl puts("lala")
#define cp cerr<<"lala"<<endl
#define fi first
#define se second
#define pb push_back
#define ln putchar('\n')
using namespace std;
inline int read()
{
char ch=getchar();int g=1,re=0;
while(ch<'0'||ch>'9') {if(ch=='-')g=-1;ch=getchar();}
while(ch<='9'&&ch>='0') re=(re<<1)+(re<<3)+(ch^48),ch=getchar();
return re*g;
}
typedef long long ll;
typedef pair<int,int> pii; inline int gcd(int a,int b)
{
while(b) {int t=a%b; a=b; b=t;}
return a;
}
const int N=7e5+11;
int prime[N],cnt=0,mu[N],smu[N],resf[N],K;
bool isnotprime[N];
void init()
{
int n=N-11;
isnotprime[1]=1; mu[1]=1;
for(int i=2;i<=n;++i)
{
if(!isnotprime[i]) prime[++cnt]=i,mu[i]=-1;
for(int j=1;j<=cnt&&i*prime[j]<=n;++j)
{
isnotprime[i*prime[j]]=1;
if(!(i%prime[j])) break;
mu[i*prime[j]]=-mu[i];
}
}
for(int i=1;i<=n;++i) smu[i]=smu[i-1]+mu[i];
for(int i=1;i<=n;++i) resf[i]=resf[i-1]+mu[i]*(gcd(i,K)==1);
} map<int,int>mp;
int M(int n)
{
if(n<=N-11) return smu[n];
if(mp.count(n)) return mp[n];
int &ans=mp[n]; ans=1;
for(int i=2,j;i<=n;i=j+1)
{
j=n/(n/i);
ans-=M(n/i)*(j-i+1);
}
return ans;
} map<int,int>F[2050];
int calcF(int k,int x)
{
if(k==1) return M(x);
if(k==K&&x<=N-11) return resf[x];
if(F[k].count(x)) return F[k][x];
int &ans=F[k][x];
for(int i=1;i*i<=k;++i) if(!(k%i))
{
if(mu[i]) ans+=mu[i]*mu[i]*calcF(i,x/i);
if(i*i!=k)
{
int oth=k/i;
if(mu[oth]) ans+=mu[oth]*mu[oth]*calcF(oth,x/oth);
}
}
return ans;
} int n,m;
int divi[2050],tot=0;
inline int f(int x)
{
int ans=0;
for(int i=1;i<=tot;++i) ans+=mu[divi[i]]*(x/divi[i]);
return ans;
} int main()
{
#ifndef ONLINE_JUDGE
freopen("1.in","r",stdin);freopen("1.out","w",stdout);
#endif
n=read(); m=read(); K=read();
init();
int mn=min(n,m);
M(mn);
for(int i=1;i*i<=K;++i) if(!(K%i))
{
divi[++tot]=i;
if(i*i!=K) divi[++tot]=K/i;
} ll ans=0;
for(int i=1,j;i<=mn;i=j+1)
{
j=min(n/(n/i),m/(m/i));
ans+=1ll*(n/i)*f(m/i)*(calcF(K,j)-calcF(K,i-1));
}
cout<<ans<<endl;
return 0;
}

uoj221【NOI2016】循环之美的更多相关文章

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

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

  2. luogu 1587 [NOI2016]循环之美

    LINK:NOI2016循环之美 这道题是 给出n m k 求出\(1\leq i\leq n,1\leq j\leq m\) \(\frac{i}{j}\)在k进制下是一个纯循环的. 由于数值相同的 ...

  3. 并不对劲的bzoj4652:loj2085:uoj221:p1587:[NOI2016]循环之美

    题目大意 对于已知的十进制数\(n\)和\(m\),在\(k\)进制下,有多少个数值上互不相等的纯循环小数,可以用\(x/y\)表示,其中 \(1\leq x\leq n,1\leq y\leq m\ ...

  4. bzoj4652 [Noi2016]循环之美

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

  5. [NOI2016]循环之美

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

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

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

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

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

  8. luogu P1587 [NOI2016]循环之美

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

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

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

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

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

随机推荐

  1. MySQL之JDBC编程增删改查

    MySQL之JDBC 一.JDBC是什么 Java DatabaseConnectivity (java语言连接数据库) 二.JDBC的本质 JDBC是SUN公司制定的一套接口(interface). ...

  2. 使用 Java 操作 Redis

    Jedis 1. 概述 Jedis 是一款使用 Java 操作 Redis 的工具,有点类似于 JDBC 2. 引入依赖 <dependency> <groupId>redis ...

  3. CF708C Centroids(树形DP)

    发现变重心就是往重心上割,所以\(\text{up and down}\),一遍统计子树最大\(size\),一遍最优割子树,\(down\),\(up\)出信息,最后\(DFS\)出可行解 #inc ...

  4. php里的$this的 含义

    $this 的含义是表示    实例化后的 具体对象! 我们一般是先声明一个类,然后用这个类去实例化对象! 但是,当我们在声明这个类的时候,想在类本身内部使用本类的属性或者方法.应该怎么表示呢? 例如 ...

  5. DTSE Tech Talk丨第3期:解密数据隔离方案,让SaaS应用开发更轻松

    摘要:解读云上前沿技术,畅聊开发应用实践.专家团队授课,答疑解惑,助力开发者使用华为云开放能力进行应用构建.技术创新. 围绕当下许多企业青睐的SaaS应用开发,华为云DTSE技术布道师李良龙为大家带来 ...

  6. @babel/runtime 和 @babel/plugin-transform-runtime 两个的作用是什么

    Babel 最基础的功能就是将采用 ECMAScript 2015+ 语法编写的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中. 最基础的依赖包也就是 ...

  7. html弹出二选一窗口,然后根据点击执行对应的js方法

    html弹出二选一窗口,然后根据点击执行对应的js方法 layer.confirm("我是弹出来的字", {btn:['确认','取消']}, function(){ ...方法1 ...

  8. Little Girl and Problem on Trees

    题意 给定一棵无边权的树,最多只有一个点度数超过2,有两种操作 1)(0 u x d)将距离u节点d距离之内的节点的值加上x 2)(1 u)询问u节点的值 n<=100000,q<=100 ...

  9. PerfView专题 (第十二篇):对 C# 下的 SDK 类库进行监控(大结局)

    一:背景 本篇是我们系列文章的最后一篇,前面的文章中大多是在 CLR Runtime 以及 OS 层面进行监控来发现各种可疑的程序问题,除了这两个层面,其实我们还可以对 SDK 中一些类进行洞察,比如 ...

  10. java基础学习:java中的反射

    一.什么是java反射 什么是 java 的反射? 说到反射,写这篇文章时,我突然想到了人的"反省",反省是什么?吾一日三省吾身,一般就是反思自身,今天做了哪些对或错的事情. ja ...