推一推
答案是

∏T(∏d|Tfμ(Td)d)⌊nT⌋⌊mT⌋

\prod_T(\prod_{d|T}f_d^{\mu({T\over d})})^{\lfloor{n\over T}\rfloor\lfloor{m\over T}\rfloor}

O(nlnn)O(n\ln n)筛一下括号里的东西,分块搞

include <cstdio>
#include <iostream>
#include <algorithm>using namespace std;typedef long long ll;const int N=1000010,P=1e9+7;int t,n,m,mu[N],p[N],g[N],f[N],h[N],invh[N];inline int Pow(int x,ll y){int ret=1;for(;y;y>>=1,x=1LL*x*x%P) if(y&1) ret=1LL*ret*x%P;return ret;
}inline void Pre(const int x){mu[1]=1;for(int i=2;i<=x;i++){if(!p[i]) p[++*p]=i,mu[i]=-1;for(int j=1;j<=*p && 1LL*p[j]*i<=x;j++)if(p[p[j]*i]=1,i%p[j]) mu[i*p[j]]=-mu[i];else{mu[i*p[j]]=0; break;}}for(int i=1;i<=x;i++) g[i]=1;f[1]=f[2]=1;for(int i=3;i<=x;i++) f[i]=(f[i-1]+f[i-2])%P;for(int i=2;i<=x;i++){int INV=Pow(f[i],P-2);for(int j=i;j<=x;j+=i){if(mu[j/i]==0) continue;if(mu[j/i]==-1) g[j]=1LL*g[j]*INV%P;else g[j]=1LL*g[j]*f[i]%P;}}h[0]=invh[0]=1;for(int i=1;i<=x;i++) h[i]=1LL*h[i-1]*g[i]%P,invh[i]=Pow(h[i],P-2);
}int ans;int main(){scanf("%d",&t); Pre(N-10);while(t--){scanf("%d%d",&n,&m);if(n>m) swap(n,m);ans=1;for(int i=1,nxt;i<=n;i=nxt+1){nxt=min(n/(n/i),m/(m/i));ans=1LL*ans*Pow(1LL*h[nxt]*invh[i-1]%P,1LL*(n/i)*(m/i))%P;}printf("%d\n",ans);}return 0;
}

[数论 反演]BZOJ4816 [Sdoi2017]数字表格相关推荐

  1. [bzoj4816][Sdoi2017]数字表格 (反演+逆元)

    (真不想做莫比乌斯了) 首先根据题意写出式子 ∏(i=1~n)∏(j=1~m)f[gcd(i,j)] 很明显的f可以预处理出来,解决 根据套路分析,我们可以先枚举gcd(i,j)==d ∏(d=1~n ...

  2. SDOI2017 数字表格

    SDOI2017 数字表格 题意: 题目传送门 题解: 答案的式子大致是这样的: \[\prod_{i = 1} ^ n \prod_{j = 1} ^ m f_{gcd(i, j)}\] 然后大力反 ...

  3. 【bzoj4816】[Sdoi2017]数字表格

    题目链接 Description Doris刚刚学习了fibonacci数列.用f[i]表示数列的第i项,那么 f[0]=0 f[1]=1 f[n]=f[n-1]+f[n-2],n>=2 Dor ...

  4. 并不对劲的bzoj4816:loj2000:p3704[SDOI2017]数字表格

    题目大意 有函数\(f(x)\),\(f(0)=0,f(1)=1,f(x)=f(x-1)+f(x-2)\) \(t\)(\(t\leq1000\))组询问,每次给定\(n,m\)(\(n,m\leq1 ...

  5. BZOJ 4816[SDOI2017]数字表格(莫比乌斯反演)

    题目链接 \(Description\) 用\(f_i\)表示\(fibonacci\)数列第\(i\)项,求\(\prod_{i=1}^{n}\prod_{j=1}^{m}f[gcd(i,j)]\) ...

  6. 【BZOJ4816】数字表格,反演+枚举约数

    传送门 思路: 考场上没怎么卡常,只有60分,感觉自己宛如一个zz 先说一下60分做法 设n≤mn\leq m 随便化出来∏d=1nf(d)S(⌊nd⌋,⌊md⌋)\displaystyle\prod ...

  7. 「luogu3704」[SDOI2017]数字表格

    莫比乌斯反演,其中一些处理比较套路 1 #include<bits/stdc++.h> 2 #define ll long long 3 using namespace std; 4 co ...

  8. [SDOI2017]数字表格

    题目描述 Doris刚刚学习了fibonacci数列.用$f[i]$ 表示数列的第$i$ 项,那么 $f[0]=0$ ,$f[1]=1$ , $f[n]=f[n-1]+f[n-2],n\geq 2$ ...

  9. BZOJ 4816 [Sdoi2017]数字表格

    题目链接 https://lydsy.com/JudgeOnline/problem.php?id=4816 题解 反演 ∏T=1min⁡(n,m)(∏d∣Tfib(d)μ(d))⌊n/d⌋⌊m/d⌋ ...

  10. 【数论】Crash的数字表格 / JZPTAB(P1829)

    正题 P1829 题目大意 给出n,m,求∑i=1n∑j=1mlcm(i,j)\sum_{i=1}^n\sum_{j=1}^mlcm(i,j)i=1∑n​j=1∑m​lcm(i,j) 解题思路 ∑i= ...

最新文章

  1. TVM自定义数据类型
  2. 监控告警满飞天,Netflix 运维如何做到在家睡到自然醒...
  3. oracle xmltype转字节,extractvalue处理XMLTYPE类型超过4000字节ORA-01706的解决方法
  4. html选择文件夹插件,js/jq仿window文件夹框选操作插件
  5. Markdown编辑器基本语法
  6. MySQL存储过程之查询受影响的行数与查询到的行数
  7. 解决数据库密码为YES的问题
  8. java项目实现服务器监控,Java实现服务器状态监控
  9. 85. Maximal Rectangle 由1拼出的最大矩形
  10. Linux TC的ifb原理以及ingress流控
  11. java反编译luyten使用
  12. ios 录音生成.aac录音文件
  13. Linux系统安装使用glassfish3.1.2.2
  14. 计算机系统基础书记,【盘点】开学第一周:学风浓 教风严 校风正
  15. Linux文件系统(一)——常用文件系统
  16. C++string中的insert()插入函数
  17. 团购模式的持久性--看书《九败一胜》
  18. 前男友的婚礼(转载)
  19. 机器学习——KNN分类器的学习
  20. 蓝海项目:在Tiktok上教老外学中文

热门文章

  1. otsu阈值分割算法原理_OTSU阈值分割
  2. CentOS7下安装NVIDIA独立显卡驱动出现X service error问题解决方法
  3. 海贼王剧场版:Z 剧情详解(附TS无字幕版地址)
  4. linux pthread_cleanup_push 线程实现,线程清理(pthread_cleanup_push函数和pthread_cleanup_pop函数)...
  5. 末学者笔记--Python基础三玄
  6. 【开发心得】如何免费用python刷网站的百度排名(已实测含源码)
  7. Python爬虫入门教程【6】:蜂鸟网图片爬取之一
  8. 基于SIMULINK的AWGN信道仿真
  9. 一个屌丝程序猿的人生(六十一)
  10. 计算机CPU核心部件简介