uoj221【NOI2016】循环之美
前面部分比较简单,就是无脑化式子,简单点讲好了。
首先肯定在\((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_{j=1}^{\frac{m}{d}}[(j,k)=1]=f(\frac{m}{d})\),它可以快速计算:
\]
\]
\]
\]
可以\(O(\sqrt k)\)计算。
回到原式
\]
这个显然可以分块吧,预处理一下\(\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。
\]
\]
\]
\]
然后由于当\((T,g)\ne 1\)时\(\mu(T*g)\)显然=0。
\]
\]
\]
然后递归算,顺便记忆化一下,另外当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】循环之美的更多相关文章
- [UOJ#221][BZOJ4652][Noi2016]循环之美
[UOJ#221][BZOJ4652][Noi2016]循环之美 试题描述 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 k 进制下,一个数的小数部 ...
- luogu 1587 [NOI2016]循环之美
LINK:NOI2016循环之美 这道题是 给出n m k 求出\(1\leq i\leq n,1\leq j\leq m\) \(\frac{i}{j}\)在k进制下是一个纯循环的. 由于数值相同的 ...
- 并不对劲的bzoj4652:loj2085:uoj221:p1587:[NOI2016]循环之美
题目大意 对于已知的十进制数\(n\)和\(m\),在\(k\)进制下,有多少个数值上互不相等的纯循环小数,可以用\(x/y\)表示,其中 \(1\leq x\leq n,1\leq y\leq m\ ...
- bzoj4652 [Noi2016]循环之美
Description 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在k进制下,一个数的小数部分是纯循环的,那么它就是美的.现在,牛牛想知道:对于已知 ...
- [NOI2016]循环之美
Description 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 k 进制下,一个数的小数部分是纯循环的,那么它就是美的.现在,牛牛想知道:对 ...
- BZOJ4652: [Noi2016]循环之美(莫比乌斯反演,杜教筛)
Description 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 k 进制下,一个数的小数部分是纯循环的,那么它就是美的.现在,牛牛想知道:对 ...
- BZOJ4652 [Noi2016]循环之美 【数论 + 莫比乌斯反演 + 杜教筛】
题目链接 BZOJ 题解 orz 此题太优美了 我们令\(\frac{x}{y}\)为最简分数,则\(x \perp y\)即,\(gcd(x,y) = 1\) 先不管\(k\)进制,我们知道\(10 ...
- luogu P1587 [NOI2016]循环之美
传送门 首先要知道什么样的数才是"纯循环数".打表可以发现,这样的数当且仅当分母和\(k\)互质,这是因为,首先考虑除法过程,每次先给当前余数\(*k\),然后对分母做带余除法,那 ...
- 题解 P1587 【[NOI2016]循环之美】
知识点:莫比乌斯反演 积性函数 杜教筛 废话前言: 我是古明地恋,写这篇题解的人已经被我 请各位读者自行无视搞事的恋恋带有删除线的内容,谢谢茄子. 这道题目本身并不难,但是公式推导/代码过程中具有迷惑 ...
- BZOJ4652 NOI2016循环之美(莫比乌斯反演+杜教筛)
因为要求数值不同,不妨设gcd(x,y)=1.由提示可以知道,x/y是纯循环小数的充要条件是x·klen=x(mod y).因为x和y互质,两边同除x,得klen=1(mod y).那么当且仅当k和y ...
随机推荐
- Docker容器保姆:在centos7.6上利用docker-compose统一管理容器和服务
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_108 众所周知,一个大型的Docker容器组成的微服务应用中,容器的数量是非常巨大的,如果依赖传统的人工配置方式进行维护,对于开发 ...
- Odoo14 ir.actions.act_window
xml声明 1 <record id="res_company_user_action" model="ir.actions.act_window"> ...
- SkiaSharp 之 WPF 自绘 粒子花园(案例版)
此案例包含了简单的碰撞检测,圆形碰撞检测方法,也可以说是五环弹球的升级版,具体可以根据例子参考. 粒子花园 这名字是案例的名字,效果更加具有科技感,很是不错,搞搞做成背景特效也是不错的选择. Wpf ...
- React报错之No duplicate props allowed
正文从这开始~ 总览 当我们为相同的组件传递相同的属性多次时,就会导致"No duplicate props allowed"警告.为了解决该警告,请确保只传递一次该属性.比如说, ...
- 你有对象类,我有结构体,Go lang1.18入门精炼教程,由白丁入鸿儒,go lang结构体(struct)的使用EP06
再续前文,在面向对象层面,Python做到了超神:万物皆为对象,而Ruby,则干脆就是神:飞花摘叶皆可对象.二者都提供对象类操作以及继承的方式为面向对象张目,但Go lang显然有一些特立独行,因为它 ...
- mybatis报错:java.io.IOException: Could not find resource /resources/mybatis-config.xml
原因: 这个图标的resources目录是根目录,在此目录下的文件直接写文件名即可
- synchronized原理剖析
synchronized原理剖析 并发编程存在什么问题? 1️⃣ 可见性 可见性:是指当一个线程对共享变量进行了修改,那么另外的线程可以立即看到修改后的最新值. 案例演示:一个线程A根据 boolea ...
- 内网渗透之vlunstack靶场
前言:vlunstack靶场是由三台虚拟机构成,一台是有外网ip的windows7系统(nat模式),另外两台是纯内网机器(外网ping不通),分别是域控win2008和内网主机win2003,这里就 ...
- python筛选excel内容并生成exe文件
最近疫情原因,班级每天都要筛选未打卡人员,每次都手动操作太麻烦了.遂写下如下的程序,并且生成了exe可执行文件. 1. 主程序 import openpyxl import pyperclip # 1 ...
- 第八十八篇:Vue keep-alive的使用 让组件"活下去""
好家伙, 1.关于keep-alive 这是一个用于阻止组件自行销毁的插件 <!-- keep-alive可以把内部组件进行缓存,而不是销毁组件 --> 那么我们什么时候会用到他呢? 举个 ...