NOIP模拟赛 拓展
题目描述 Description###
\(φ\) 函数是数论中非常常用的函数。对于正整数 \(x\) ,\(φ(x)\) 表示不超过 \(x\) 的所有正整数与 \(x\) 互质的个数。
现在我们对它进行一次拓展:对于正整数 \(x\) ,\(y\) ,定义 \(φ(x,y)\) 表示不超过 \(y\) 的所有正整数与 \(x\) 互质的个数。
现在我们给定正整数 \(n\) 和 \(m\) ,对于所有不超过 \(n\) 的正整数 \(i\) ,求 \(φ(i,m)\) 。
输入描述 Input Description###
输入仅一行两个正整数 \(n\) 和 \(m\) 。
输出描述 Output Description###
输出 \(n\) 行,每行一个整数。第 \(i\) 行表示 \(φ(i,m)\) 。
样例输入 Sample Input###
11 10
样例输出 Sample Output###
10
5
7
5
8
3
9
5
7
4
10
数据范围及提示 Data Size & Hint###
\(n \leq 10^5,m \leq 10^{15}\)
之前的一些废话###
题解###
正难则反,我们考虑\(m\) 以内能被\(n\) 整除的所有数,含有所有\(n\) 的因子的很显然是可以的,然后我们就可以通过容斥原理来加加减减来求得这个值,找找规律可以发现,含有平方因子的数不会参与其中的讨论,含有奇数个质因子的数应该是加,含有偶数个质因子的数应该是减,所以我们来一个素数筛来预处理每一个数的符号,然后$\sqrt{i} $ 的时间枚举每一个i的因数,然后进行计算。复杂度$ O(预处理+n\sqrt{n} )$
代码###
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
typedef long long LL;
typedef pair<int,int> PII;
#define X first
#define Y second
#define mp make_pair
#define mem(a,b) memset(a,b,sizeof(a))
inline LL read()
{
LL x=0,f=1;char c=getchar();
while(!isdigit(c)){if(c=='-')f=-1;c=getchar();}
while(isdigit(c)){x=x*10+c-'0';c=getchar();}
return x*f;
}
const int maxn=100000;
int n,prime[maxn],end,sign[maxn+20];
LL m,sum;
bool vis[maxn+20];
void init()
{
for(int i=2;i<=maxn;i++)
if(!vis[i])
{
prime[++end]=i;
for(LL j=(LL)i*(LL)i;j<=(LL)maxn;j+=i)vis[j]=1;
}
for(int i=2;i<=maxn;i++)
{
if(!vis[i])sign[i]=1;
if(!sign[i])continue;
for(int j=1;j<=end && (LL)i*(LL)prime[j]<=maxn;j++)
{
if(i%prime[j]==0)sign[i*prime[j]]=0;
else sign[i*prime[j]]=-sign[i];
}
}
}
int main()
{
init();
n=(int)read();m=read();
printf("%lld\n",m);
for(int i=2;i<=n;i++)
{
int s=(int)sqrt(i);
sum=0ll;
for(int j=1;j<=s;j++)
if(i%j==0)
{
if(j!=1)sum+=(m/j)*sign[j];
if(j*j!=i)sum+=(m/(i/j))*sign[i/j];
}
printf("%lld\n",m-sum);
}
return 0;
}
总结###
找找规律画画图这种题还是比较简单的。
事后发现这玩意居然是莫比乌斯函数,我居然自己推出了这么高深的东西!
NOIP模拟赛 拓展的更多相关文章
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程
数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...
- CH Round #58 - OrzCC杯noip模拟赛day2
A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...
- CH Round #52 - Thinking Bear #1 (NOIP模拟赛)
A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...
随机推荐
- hdu6464 线段树
http://acm.hdu.edu.cn/showproblem.php?pid=6464 题意 一个空序列,q次操作,一种是往序列后插入x个y,另一种是查询序列中第x小到第y小的数字之和 题解 线 ...
- Nacos集群搭建过程详解
Nacos的单节点,也就是我们最开始使用的standalone模式,配置的数据是默认存储到内嵌的数据库derby中. 如果我们要搭建集群的话,那么肯定是不能用内嵌的数据库,不然数据无法共享.集群搭建的 ...
- 02-Git远程仓库Github
1.Git远程仓库 (Gitgub网站作为远程代码仓库时的操作和本地代码仓库一样的,只是仓库位置不同而已) 需要准备的东西: 1.准备Git源代码仓库https://github.com/ 2.准备李 ...
- 基础面试,为什么面试官总喜欢问String?
关于 Java String,这是面试的基础,但是还有很多童鞋不能说清楚,所以本文将简单而又透彻的说明一下那个让你迷惑的 String 在 Java 中,我们有两种方式创建一个字符串 String x ...
- hive creating temporary folder on: Error encountered near token 'TOK_TMP_FILE'
执行create tmp.tablename as select .....语句的时候报以下错误: SemanticException 0:0 creating temporary folder o ...
- Web前端基础(3):HTML(三)
1. body中的相关标签 1.1 表格标签:table.tr.td HTML表格由<table>标签以及一个或多个<tr>.<th>或<td>标签组成 ...
- Django---SETTINGS配置(***)
Django---SETTINGS核心配置项 django核心配置项 Django的默认配置文件中,包含上百条配置项目,其中很多是我们'一辈子'都不碰到或者不需要单独配置的,这些项目在需要的时候再去查 ...
- Winform中在ZedGraph中最多可以添加多少条曲线
场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- CSS设置文本的水平对齐方向
介绍 在CSS中text-align属性有3种值,如下:left左.center中.right右. 由于简单我就不再多的介绍了直接进入text-align属性实践了,如果大家是新手自己一定要去实践哈, ...
- JavaScript深入浅出第1课:箭头函数中的this究竟是什么鬼?
<JavaScript 深入浅出>系列: JavaScript 深入浅出第 1 课:箭头函数中的 this 究竟是什么鬼? JavaScript 深入浅出第 2 课:函数是一等公民是什么意 ...