题目描述

大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞票。房地产第一大户沙拉公主决定预测一下大富翁国现在所有真钞票的数量。现在,请你帮助沙拉公主解决这个问题,由于可能张数非常大,你只需计算出对R取模后的答案即可。R是一个质数。

输入

第一行为两个整数T,R。R<=10^9+10,T<=10000,表示该组中测试数据数目,R为模后面T行,每行一对整数N,M,见题目描述 m<=n

输出

共T行,对于每一对N,M,输出1至N!中与M!素质的数的数量对R取模后的值

样例输入

1 11
4 2

样例输出

1


题解

欧拉函数

如果a与m互质,那么a+m与m一定也互质,a+2m与m一定也互质,a+(k-1)m与m一定也互质。

所以km中与m互质的数是m中与m互质的数的k倍,即kφ(m)

注意到这里边N!是M!的倍数,所以所求即为N!/M!*φ(M!)

而φ(M!)=M!*∏(p-1)/p,p为M的质因子,所以所求就是N!/∏p,我们只需要预处理出1/∏p即可。这里我们需要筛素数和求逆元。

然后学到了一种O(n)递推求逆元的方法:ine[i]=(R-R/i*ine[R%i]%R)

这样就能够在O(n)时间内预处理出1/∏p,最后再乘上N!即可。

#include <cstdio>
#define N 10000010
typedef long long ll;
const int n = 10000000;
int fac[N] , ine[N] , ans[N] , phi[N] , prime[N] , tot;
bool np[N];
int main()
{int T , p , i , j , x , y;scanf("%d%d" , &T , &p);fac[1] = phi[1] = ine[1] = ans[1] = 1;for(i = 2 ; i <= n ; i ++ ){fac[i] = (ll)fac[i - 1] * i % p , ine[i] = (ll)(p - p / i) * ine[p % i] % p , ans[i] = ans[i - 1];if(!np[i]) phi[i] = i - 1 , ans[i] = (ll)ans[i] * (i - 1) % p * ine[i % p] % p , prime[++tot] = i;for(j = 1 ; j <= tot && i * prime[j] <= n ; j ++ ){np[i * prime[j]] = 1;if(i % prime[j] == 0){phi[i * prime[j]] = phi[i] * prime[j];break;}else phi[i * prime[j]] = phi[i] * (prime[j] - 1);}}while(T -- ) scanf("%d%d" , &x , &y) , printf("%lld\n" , (ll)fac[x] * ans[y] % p);return 0;
}

转载于:https://www.cnblogs.com/GXZlegend/p/6999264.html

【bzoj2186】[Sdoi2008]沙拉公主的困惑 欧拉函数相关推荐

  1. [SDOI2008]沙拉公主的困惑 线性筛 素数+欧拉

    本文为博主原创文章,欢迎转载,请注明出处 www.cnblogs.com/yangyaojia [SDOI2008]沙拉公主的困惑 线性筛 素数+欧拉 题目大意 给定n,m,求在1到n!内与m!互质的 ...

  2. bzoj2186【SDOI2008】沙拉公主的困惑

    2186: [Sdoi2008]沙拉公主的困惑 Time Limit: 10 Sec   Memory Limit: 259 MB Submit: 2363   Solved: 779 [ Submi ...

  3. φ(1)=1 [Sdoi2008]沙拉公主的困惑

    问题 F: [Sdoi2008]沙拉公主的困惑 时间限制: 1 Sec 内存限制: 259 MB 题目描述 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘 ...

  4. [bzoj2186]沙拉公主的困惑

    2186 沙拉公主的困惑 Time Limit: 10 Sec   Memory Limit: 259 MB Description 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有 ...

  5. 沙拉公主的困惑 cash

    一.沙拉公主的困惑 (cash.pas/c/cpp, 限时3 秒,内存256M) [题目描述] 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编 号范围为1 到N 的阶乘,但是 ...

  6. 欧拉线性筛 与 欧拉函数 + 几道例题

    欧拉线性筛 生成素数表prime[]数组 const int maxn = 1e7+5; int prime[maxn]; int visit[maxn]; void Prime(){memset(v ...

  7. 【微分方程数值解】常微分方程(一)欧拉方法和改进欧拉方法(附python算例,封装类)

    欧拉方法与改进欧拉方法 一.算法原理 对给定微分方程 {y′=f(x,y)y(x0)=y0(1)\begin{cases} y' = f(x,y)\\ y(x_0) = y_0 \end{cases} ...

  8. 微分方程一维抛物热传导方程向前向后欧拉C-N格式二阶BDF格式MATLAB源码 显式欧拉,隐式欧拉,梯形公式,改进欧拉

    微分方程一维抛物热传导方程向前向后欧拉C-N格式二阶BDF格式MATLAB源码 显式欧拉,隐式欧拉,梯形公式,改进欧拉 五点差分,九点差分 差分格式,紧差分格式 直拍,只有pdf版方法说明 word版 ...

  9. bzoj 2186: [Sdoi2008]沙拉公主的困惑

    Time Limit: 10 Sec  Memory Limit: 259 MB Submit: 2463  Solved: 820 [Submit][Status][Discuss] Descrip ...

最新文章

  1. OPPO和微软合作,开放“召唤小冰”
  2. 【Vegas原创】outlook连接exchange需要密码的解决方法
  3. Python 2.7终结于7个月后,这是你需要了解的3.X炫酷新特性
  4. 天气webservice服务
  5. 界面 高炉系统_首钢京唐七大系统介绍
  6. Python3 基础学习笔记 C06【用户输入和 while 循环】
  7. 数据结构-树3-红黑树
  8. 深度学习 - MPII Human Pose Database数据集下载
  9. 如何经营一家培训机构?
  10. 怎样从excel随机抽取多行
  11. 直播系统app源码,简单实现颜色渐变
  12. 资源监视器中看不到磁盘队列等等问题的解决方案
  13. IP数据包格式各字段详解说明
  14. Postgresql去掉某个字段多余的空格
  15. 算法设计与分析——字符a~h出现的频率恰好是前8个斐波那契数——斐波那契数和霍夫曼编码的关系——数学证明
  16. Arduino 利用串口缓冲区监听的方式读取数据
  17. 51单片机:共阴数码管动态显示(定时器+中断)
  18. 市场估值-指数PE讨论
  19. 轻量化网络结构——MobileNet
  20. 【商业挖掘】关联规则——Apriori算法(最全~)

热门文章

  1. python基础代码事例-Python基础总结成千行代码,让Python入门更简单!
  2. python与excel做数据可视化-用Python进行数据可视化的10种方法
  3. 学python用什么软件开发-5款Python程序员高频使用开发工具推荐
  4. python常见错误-Python 常见报错类型
  5. python在线编译-python在线编译器的简单原理及简单实现代码
  6. python 画图 内存-python的内存分析和处理
  7. python生成折线图-Python数据可视化 -生成数据之绘制折线图和散点图
  8. python课程费用-Python在线培训课程费用是多少?值不值得报名?
  9. python有哪些作用-python能用来做什么?Python都有哪些逆天的功能
  10. python资料百度网盘-python自动保存百度盘资源到百度盘中的实例代码