【题目链接】

点击打开链接

【算法】

gcd(a,b)=gcd(a mod b, b),又m!|n!
          则有ans=(n!/m!)·ϕ(m!)
          由ϕ(n)=n(1-1/p1)(1-1/p2)...(1-1/pk)
          ans=n!(1-1/p1)(1-1/p2)...(1-1/pk)
          这里p1...pk为m!的所有质因子,即不大于m的所有素数。
          设f(n)=n!,g(m)=(1-1/p1)(1-1/p2)...(1-1/pk)
          都能在O(n)时间内预处理(利用线性筛和线性求逆元)

则ans=f(n)g(m),O(1)回答询问。

【代码】

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int MAXN = ;
  4. typedef long long ll;
  5.  
  6. ll i,k,tmp,T,R,N,M,tot;
  7. ll prime[],t[MAXN+];
  8. int f[MAXN+],fac[MAXN+],inv[MAXN+];
  9.  
  10. template <typename T> inline void read(T &x) {
  11. ll f = ; x = ;
  12. char c = getchar();
  13. for (; !isdigit(c); c = getchar()) { if (c == '-') f = -f; }
  14. for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
  15. x *= f;
  16. }
  17. template <typename T> inline void write(T x) {
  18. if (x < ) { putchar('-'); x = -x; }
  19. if (x > ) write(x/);
  20. putchar(x%+'');
  21. }
  22. template <typename T> inline void writeln(T x) {
  23. write(x);
  24. puts("");
  25. }
  26.  
  27. int main() {
  28.  
  29. read(T); read(R);
  30.  
  31. for (i = ; i <= MAXN; i++) {
  32. if (!f[i]) prime[++tot] = f[i] = i;
  33. for (k = ; k <= tot; k++) {
  34. tmp = i * prime[k];
  35. if (tmp > MAXN) break;
  36. f[tmp] = prime[k];
  37. if (f[i] == prime[k]) break;
  38. }
  39. }
  40. fac[] = ; inv[] = ; t[] = ;
  41. for (i = ; i <= MAXN; i++) fac[i] = fac[i-] * i % R;
  42. for (i = ; i <= MAXN && i < R; i++) inv[i] = (R - R / i) * inv[R%i] % R;
  43. for (i = ; i <= MAXN; i++) {
  44. if (f[i] != i) t[i] = t[i-];
  45. else t[i] = t[i-] * (i - ) % R * inv[i%R] % R;
  46. }
  47. while (T--) {
  48. read(N); read(M);
  49. writeln(fac[N]*t[M]%R);
  50. }
  51.  
  52. return ;
  53. }

【Sdoi2008】沙拉公主的困惑的更多相关文章

  1. Bzoj 2186: [Sdoi2008]沙拉公主的困惑 乘法逆元,线性筛,欧拉函数,数论

    2186: [Sdoi2008]沙拉公主的困惑 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 2560  Solved: 857[Submit][St ...

  2. 数学(逆元):BZOJ 2186: [Sdoi2008]沙拉公主的困惑

    2186: [Sdoi2008]沙拉公主的困惑 Description 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞 ...

  3. 洛咕 P2155 [SDOI2008]沙拉公主的困惑

    洛咕 P2155 [SDOI2008]沙拉公主的困惑 有个结论,就是如果\(gcd(a,b)=1\),那么\(gcd(a+kb,b)=1\).证明比较显然. 所以这个题目要问的\(n!\)就可以分成\ ...

  4. BZOJ2186: [Sdoi2008]沙拉公主的困惑(求[1,N!]与M!互素的个数)(线性筛)

    2186: [Sdoi2008]沙拉公主的困惑 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 6103  Solved: 2060[Submit][S ...

  5. BZOJ2186 [Sdoi2008]沙拉公主的困惑 【数论,欧拉函数,线性筛,乘法逆元】

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

  6. 【BZOJ 2186】 2186: [Sdoi2008]沙拉公主的困惑 (欧拉筛,线性求逆元)

    2186: [Sdoi2008]沙拉公主的困惑 Description 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞 ...

  7. 【bzoj2186】[Sdoi2008]沙拉公主的困惑

    2186: [Sdoi2008]沙拉公主的困惑 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 3303  Solved: 1129[Submit][S ...

  8. 【BZOJ2186】[Sdoi2008]沙拉公主的困惑 线性筛素数

    [BZOJ2186][Sdoi2008]沙拉公主的困惑 Description 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M! ...

  9. 【bzoj2186】: [Sdoi2008]沙拉公主的困惑 数论-欧拉函数

    [bzoj2186]: [Sdoi2008]沙拉公主的困惑 考虑当 gcd(a,b)=1 则 gcd(nb+a,b)=1 所以[1,N!]与M!互质的个数就是 筛出[1,M]所有的素数p[i] 以及逆 ...

  10. 洛谷 P2155 [SDOI2008]沙拉公主的困惑 解题报告

    P2155 [SDOI2008]沙拉公主的困惑 题目描述 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为\(1\)到\(N\)的阶乘,但是,政府只发行编号与\(M!\ ...

随机推荐

  1. Callable和Runnable和FutureTask

    http://www.cnblogs.com/dolphin0520/p/3949310.html 一.Callable与Runnable 二.Future 三.FutureTask 四.使用示例 一 ...

  2. python3.x对python2.x变动

    原文地址:http://rookiedong.iteye.com/blog/1185403 python 2.4 与 python 3.0 的比较 一. print 从语句变为函数 原:     pr ...

  3. [Bzoj3676][Apio2014]回文串(后缀自动机)(parent树)(倍增)

    3676: [Apio2014]回文串 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 3396  Solved: 1568[Submit][Statu ...

  4. bzoj 5091: [Lydsy0711月赛]摘苹果

    5091: [Lydsy0711月赛]摘苹果 Time Limit: 1 Sec  Memory Limit: 256 MBSubmit: 148  Solved: 114[Submit][Statu ...

  5. Java全局变量不加修饰符时的访问权限范围

    如上图所示.

  6. amplab

    https://github.com/amplab/SparkNet https://amplab.cs.berkeley.edu/

  7. winform客户端程序实时读写app.config文件

    新接到需求,wcf客户端程序运行时,能实时修改程序的打印机名称: 使用XmlHelper读写 winform.exe.config文件修改后始终,不能实时读取出来,查询博客园,原来已有大神解释了: 获 ...

  8. 转:linux下ip修改与域名解析查看等

    转自: http://www.justwinit.cn/post/7038/ IP:     ifconfiggateway:172.16.0.254 [root@localhost ~]# nets ...

  9. leetcode Valid Palindrome C++&amp;python 题解

    题目描写叙述 Given a string, determine if it is a palindrome, considering only alphanumeric characters and ...

  10. NVIDIA---CUDA

    http://en.wikipedia.org/wiki/CUDA CUDA From Wikipedia, the free encyclopedia     CUDA Developer(s) N ...