题解

我们要求的其实是这个东西= =

\(\sum_{i = 1}^{n}\sum_{j = 1}^{n}[(i,j) == 1][(j,k) == 1]\)

然后变一下形

\(\sum_{j = 1}^{n}[(j,k) == 1]\sum_{i = 1}^{n}[(i,j) == 1]\)

\(\sum_{j = 1}^{n}[(j,k) == 1]\sum_{i = 1}^{n}\sum_{d|i,j}\mu(d)\)

\(\sum_{j = 1}^{n}[(j,k) == 1]\sum_{d | j} \mu(d) \lfloor \frac{n}{d} \rfloor\)

\(\sum_{d = 1}^{n} \mu(d) \lfloor \frac{n}{d} \rfloor \sum_{y = 1}^{\lfloor \frac{m}{d} \rfloor}[(yd,k) == 1]\)

\(\sum_{d = 1}^{n} \mu(d) \lfloor \frac{n}{d} \rfloor \sum_{y = 1}^{\lfloor \frac{m}{d} \rfloor}[(d,k) == 1][(y,k) == 1]\)

\(\sum_{d = 1}^{n} [(d,k) == 1] \mu(d) \lfloor \frac{n}{d} \rfloor \sum_{y = 1}^{\lfloor \frac{m}{d} \rfloor}[(y,k) == 1]\)

设\(f(n) = \sum_{i = 1}^{n}[(i,k) == 1]\)

我们可以预处理\(f(1)\)到\(f(k)\)

那么就有

\(f(n) = \lfloor\frac{n}{k}\rfloor f(k) + f(n mod k)\)

因为\((a,b) == 1\) 等价于\((a mod b,b) == 1\)

我们现在可以\(O(n)\)解决这个式子了,但是还不够

我们可以用数论分块处理\(\lfloor \frac{n}{d} \rfloor\) 和 \(\lfloor \frac{m}{d} \rfloor\)

我们尝试算

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

设\(g(n,k) = \sum_{d = 1}^{n} [(d,k) == 1] \mu(d)\)

我们选择一个\(k\)的质因子\(p\),然后把\(k\)表示成\(p^{c}q\)的形式

我们从和\(q\)互质的数里除掉和\(p\)互质的数

\(g(n,k) = \sum_{d = 1}^{n} [(d,q) == 1] \mu(d) - \sum_{y = 1}^{n} [(yp,q) == 1] \mu(yp)\)

由于\(p\)和\(q\)互质,所以我们只需要保证\([(y,p) == 1][(y,q) == 1]\)

\(g(n,k) = \sum_{d = 1}^{n} [(d,q) == 1] \mu(d) - \mu(p) \sum_{y = 1}^{n} [(y,p) == 1][(y,q) == 1] \mu(y)\)

\(g(n,k) = \sum_{d = 1}^{n} [(d,q) == 1] \mu(d) + \sum_{y = 1}^{\lfloor \frac{n}{d} \rfloor} [(y,k) == 1]\mu(y)\)

\(g(n,k) = g(n,q) + g(\lfloor \frac{n}{p} \rfloor,k)\)

边界是\(n <= 1\)返回\(n\),\(k = 1\)返回一个莫比乌斯函数的前缀和,可以杜教筛

代码

#include <bits/stdc++.h>
//#define ivorysi
#define enter putchar('\n')
#define space putchar(' ')
#define fi first
#define se second
#define pb push_back
#define mp make_pair
#define eps 1e-8
#define mo 974711
#define MAXN 1000000
#define pii pair<int,int>
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
res = 0;char c = getchar();T f = 1;
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {putchar('-');x = -x;}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
int N,M,K;
int mu[MAXN + 5],prime[MAXN + 5],tot,Mu[MAXN + 5];
bool nonprime[MAXN + 5];
int f[2005];
struct HASH {
struct node {
int64 x,v;
int next;
}E[MAXN * 2];
int head[mo + 5],sumE;
HASH() {
memset(head,0,sizeof(head));sumE = 0;
}
void add(int u,int64 x,int64 v) {
E[++sumE].x = x;E[sumE].v = v;E[sumE].next = head[u];
head[u] = sumE;
}
void Insert(int64 x,int64 v) {
add(x % mo,x,v);
}
int64 Query(int64 x){
for(int i = head[x % mo] ; i ; i = E[i].next) {
if(E[i].x == x) return E[i].v;
}
return -1;
}
}H[2];
int gcd(int a,int b) {
return b == 0 ? a : gcd(b,a % b);
}
int64 calcF(int x) {
return 1LL * (x / K) * f[K] + f[x % K];
}
int64 S(int x) {
if(x <= MAXN) return Mu[x];
int64 c = H[0].Query(x);
if(c != -1) return c;
int64 res = 0;
for(int i = 2 ; i <= x ; ++i) {
int r = x / (x / i);
res = res + 1LL * (r - i + 1) * S(x / i);
i = r;
}
res = 1 - res;
H[0].Insert(x,res);
return res;
}
int64 G(int n,int k) {
if(k == 1) return S(n);
else if(n <= 1) return n;
int64 c = H[1].Query(1LL * (n - 1) * K + k);
if(c != -1) return c;
for(int i = 1 ; i <= tot ; ++i) {
if(k % prime[i] == 0) {
int x = k;
while(x % prime[i] == 0) x /= prime[i];
int64 res = G(n,x) + G(n / prime[i],x * prime[i]);
H[1].Insert(1LL * (n - 1) * K + k,res);
return res;
}
} }
void Solve() {
int t = min(N,M);
int64 res = 0;
for(int i = 1 ; i <= t ; ++i) {
int r = min(N / (N / i),M / (M / i));
int64 s = calcF(M / i) * (N / i);
res = res + s * (G(r,K) - G(i - 1,K));
i = r;
}
out(res);enter;
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
read(N);read(M);read(K);
mu[1] = 1;Mu[1] = 1;
for(int i = 2 ; i <= MAXN ; ++i) {
if(!nonprime[i]) {
prime[++tot] = i;
mu[i] = -1;
}
for(int j = 1 ; j <= tot ; ++j) {
if(prime[j] > MAXN / i) break;
nonprime[i * prime[j]] = 1;
if(i % prime[j] == 0) break;
else mu[i * prime[j]] = -mu[i];
}
Mu[i] = Mu[i - 1] + mu[i];
}
for(int i = 1 ; i <= K ; ++i) {
f[i] = f[i - 1] + (gcd(i,K) == 1);
}
Solve();
return 0;
}

【LOJ】#2085. 「NOI2016」循环之美的更多相关文章

  1. *LOJ#2085. 「NOI2016」循环之美

    $n \leq 1e9,m \leq 1e9,k \leq 2000$,求$k$进制下$\frac{x}{y}$有多少种不同的纯循环数取值,$1 \leq x \leq n,1 \leq y \leq ...

  2. LibreOJ2085 - 「NOI2016」循环之美

    Portal Description 给出\(n,m(n,m\leq10^9)\)和\(k(k\leq2000)\),求在\(k\)进制下,有多少个数值不同的纯循环小数可以表示成\(\dfrac{x} ...

  3. 「NOI2016」循环之美 解题报告

    「NOI2016」循环之美 对于小数\(\frac{a}{b}\),如果它在\(k\)进制下被统计,需要满足要求并且不重复. 不重复我们确保这个分数是最简分数即\((a,b)=1\) 满足要求需要满足 ...

  4. LOJ 2085: 洛谷 P1587: bzoj 4652: 「NOI2016」循环之美

    题目传送门:LOJ #2085. 两个月之前做的傻题,还是有必要补一下博客. 题意简述: 求分子为不超过 \(n\) 的正整数,分母为不超过 \(m\) 的正整数的所有互不相等的分数中,有多少在 \( ...

  5. 「NOI2016」循环之美

    P1587 [NOI2016]循环之美 题目描述 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 $k$ 进制下,一个数的小数部分是纯循环的,那么它就 ...

  6. 「NOI2016」循环之美(小性质+min_25筛)

    传送门. 题解 感觉这题最难的是第一个结论. x/y首先要互质,然后如果在10进制是纯循环小数,不难想到y不是2.5的倍数就好了. 因为十进制下除以2和5是除得尽的. 必然会多出来的什么东西. 如果是 ...

  7. 【刷题】LOJ 2818 「eJOI2018」循环排序

    题目描述 本题译自 eJOI2018 Problem F「Cycle Sort」 给定一个长为 \(n\) 的数列 \(\{a_i\}\) ,你可以多次进行如下操作: 选定 \(k\) 个不同的下标 ...

  8. LOJ#2086. 「NOI2016」区间

    $n \leq 500000$个区间,从中挑出一些,使得至少有一个点被$m$个选中区间包含,且选中区间长度的极差最小. 区间题死脑筋晚期:把区间按左端点排序,然后右端点用个优先队列来弹,然后需要维护下 ...

  9. LOJ#2084. 「NOI2016」网格

    $n,m \leq 1e9$,$n*m$的网格中有$c \leq 1e5$个是黑的,其他是白的.问:使至少两个白的不连通,最少需要再把几个白的涂黑. 可以发现答案是-1,0,1,2啦.-1要么没白的, ...

随机推荐

  1. P1801 黑匣子_NOI导刊2010提高(06)

    P1801 黑匣子_NOI导刊2010提高(06) 题目描述 Black Box是一种原始的数据库.它可以储存一个整数数组,还有一个特别的变量i.最开始的时候Black Box是空的.而i等于0.这个 ...

  2. 题解 P4092 【[HEOI2016/TJOI2016]树】

    参考了皎月半洒花的博客 看到树想到树剖,由于要取距自己到根离自己最近的标记点,刚开始想到线段树里存节点深度,查询时返回最大值.但是这样的话只能得到节点深度,无法得知节点编号,就想倍增乱搞一下,求出标记 ...

  3. TCP与UDP区别详解

    TCP协议与UDP协议的区别    首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! ...

  4. shell多进程的实现

    需求:多个脚本彼此互不干涉,同时运行,节省时间 菜鸟级实现: #!/bin/sh dir="/data/test" $dir/sbin/test1.sh >> $dir ...

  5. excel表格添加固定宽高的图片

    import xlsxwriter,xlrd import glob #打开excel文件 data=xlrd.open_workbook('优秀创意库-20180725.xlsx') #获取第一张工 ...

  6. 51nod 1073 约瑟夫环

    题目链接 先说一下什么是约瑟夫环,转自:传送门 关于约瑟夫环问题,无论是用链表实现还是用数组实现都有一个共同点:要模拟整个游戏过程,不仅程序写起来比较烦,而且时间复杂度高达O(nm),当n,m非常大( ...

  7. WordPress的SEO插件——WordPress SEO by yoast安装及使用

    插件:WordPress SEO by yoast 使用方法: 做好网站SEO一直是站长们的愿望,说简单也简单,但是说难也难,因为需要注意的地方太多,一个不小心被百度K了你都不知道怎么回事.这里和大家 ...

  8. Where can I check in?

    Where can I check in? 在哪儿办理登记手续?

  9. django框架之中间件

    中间件简介 django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法. 在djang ...

  10. keepalived主备切换后的arp问题【转】

    使用keepalived的时候主机挂了,备机显示绑定了VIP.但是此时实际还是不能访问.其实就是网关的arp缓存没有刷新.   在服务器上执行一下就行了 arping -I eth0 -c 5 -s ...