题目描述 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###

  1. 11 10

样例输出 Sample Output###

  1. 10
  2. 5
  3. 7
  4. 5
  5. 8
  6. 3
  7. 9
  8. 5
  9. 7
  10. 4
  11. 10

数据范围及提示 Data Size & Hint###

\(n \leq 10^5,m \leq 10^{15}\)

之前的一些废话###

题解###

正难则反,我们考虑\(m\) 以内能被\(n\) 整除的所有数,含有所有\(n\) 的因子的很显然是可以的,然后我们就可以通过容斥原理来加加减减来求得这个值,找找规律可以发现,含有平方因子的数不会参与其中的讨论,含有奇数个质因子的数应该是加,含有偶数个质因子的数应该是减,所以我们来一个素数筛来预处理每一个数的符号,然后$\sqrt{i} $ 的时间枚举每一个i的因数,然后进行计算。复杂度$ O(预处理+n\sqrt{n} )$

代码###

  1. #include<iostream>
  2. #include<cmath>
  3. #include<algorithm>
  4. #include<cstdio>
  5. #include<queue>
  6. #include<cstring>
  7. using namespace std;
  8. typedef long long LL;
  9. typedef pair<int,int> PII;
  10. #define X first
  11. #define Y second
  12. #define mp make_pair
  13. #define mem(a,b) memset(a,b,sizeof(a))
  14. inline LL read()
  15. {
  16. LL x=0,f=1;char c=getchar();
  17. while(!isdigit(c)){if(c=='-')f=-1;c=getchar();}
  18. while(isdigit(c)){x=x*10+c-'0';c=getchar();}
  19. return x*f;
  20. }
  21. const int maxn=100000;
  22. int n,prime[maxn],end,sign[maxn+20];
  23. LL m,sum;
  24. bool vis[maxn+20];
  25. void init()
  26. {
  27. for(int i=2;i<=maxn;i++)
  28. if(!vis[i])
  29. {
  30. prime[++end]=i;
  31. for(LL j=(LL)i*(LL)i;j<=(LL)maxn;j+=i)vis[j]=1;
  32. }
  33. for(int i=2;i<=maxn;i++)
  34. {
  35. if(!vis[i])sign[i]=1;
  36. if(!sign[i])continue;
  37. for(int j=1;j<=end && (LL)i*(LL)prime[j]<=maxn;j++)
  38. {
  39. if(i%prime[j]==0)sign[i*prime[j]]=0;
  40. else sign[i*prime[j]]=-sign[i];
  41. }
  42. }
  43. }
  44. int main()
  45. {
  46. init();
  47. n=(int)read();m=read();
  48. printf("%lld\n",m);
  49. for(int i=2;i<=n;i++)
  50. {
  51. int s=(int)sqrt(i);
  52. sum=0ll;
  53. for(int j=1;j<=s;j++)
  54. if(i%j==0)
  55. {
  56. if(j!=1)sum+=(m/j)*sign[j];
  57. if(j*j!=i)sum+=(m/(i/j))*sign[i/j];
  58. }
  59. printf("%lld\n",m-sum);
  60. }
  61. return 0;
  62. }

总结###

找找规律画画图这种题还是比较简单的。

事后发现这玩意居然是莫比乌斯函数,我居然自己推出了这么高深的东西!

NOIP模拟赛 拓展的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  6. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  7. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  8. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

  9. CH Round #52 - Thinking Bear #1 (NOIP模拟赛)

    A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...

随机推荐

  1. Java之Random类

    什么是Random类 此类的实例用于生成伪随机数,使用此类中的方法能够得到一个随机数. Random使用步骤 查看类 java.util.Random :该类需要 import导入使后使用. 查看构造 ...

  2. BZOJ1001/LG4001 「ICPC Beijing2006」狼抓兔子 平面图最小割转对偶图最短路

    问题描述 BZOJ1001 LG4001 题解 平面图最小割=对偶图最短路 假设起点和终点间有和其他边都不相交的一条虚边. 如图,平面图的若干条边将一个平面划分为若干个图形,每个图形就是对偶图中的一个 ...

  3. ZEN、ELECTRA、ALBERT

    一.ZEN 目前,大多数中文预训练模型基本上沿用了英文模型的做法,聚焦于小颗粒度文本单元(字)的输入.然而,与英文相比,中文没有空格等明确的词语边界.这个特点使得很多文本表达中存在的交叉歧义也被带入了 ...

  4. manage.py相关命令

    python manage.py makemigrations <app_name> 在对应app下的migrations目录下,生成XXXX_initial.py文件,该XXXX_ini ...

  5. SQL Server字符串函数STUFF的使用

    前言: 最近有个实践练习是将学生报名数据表student中的[st_id]字段的第二个和第三个字符删除,然后在此位置插入新的字符串“200900”,其实就是替换的意思,生成新的字符串. STUFF 函 ...

  6. IT兄弟连 Java语法教程 数组 深入数组 内存中的数组

    数组是一种引用数据类型,数组引用变量只是一个引用,数组元素和数组变量在内存里是分开存放的.下面将深入介绍数组在内存中的运行机制. 内存中的数组 数组引用变量只是一个引用,这个引用变量可以指向任何有效的 ...

  7. Spring Session工作原理

    本文首发于 vivo互联网技术 微信公众号 https://mp.weixin.qq.com/s/KCOFv0nRuymkX79-RZi9eg 作者:张正林 目录:1.引入背景2.使用方法3.工作流程 ...

  8. MySQL中的group_concat函数的使用

    本文通过实例介绍了MySQL中的group_concat函数的使用方法,比如select group_concat(name) . MySQL中group_concat函数 完整的语法如下: grou ...

  9. windows7_删除”右键-新建“菜单中的多余项

    这边文章比较好用:分享下 https://blog.csdn.net/ddgweb/article/details/17993251 在使用windows7的过程中,由于安装了较多的软件,在桌面或者资 ...

  10. 【LeetCode】2. 两数相加

    题目 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.   如果,我们将这两个数相加起来,则会返回一个新的链表来表 ...