首页 > 代码库 > 【3288】Mato矩阵 打表找规律
【3288】Mato矩阵 打表找规律
首先行列式不多说了。
然后这道题可以用类似高斯消元的方法暴力搞到部分分。
但是正解是1~n求一遍欧拉函数,乘起来就是答案了。
这个怎么搞出来的呢?
考试的时候首先我们会打个暴力,然后排一下,然后发现,,,欧拉函数!
嗯。就是这样。
代码:
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define N 1001000 #define MOD 1000000007 using namespace std; int n,prime[N],cnt; long long phi[N]; bool vis[N]; void array() { int i,j; phi[1]=1; for(i=2;i<=n;i++) { if(!vis[i])prime[++cnt]=i,phi[i]=i-1; for(j=1;prime[j]*i<=n;j++) { vis[prime[j]*i]=true; if(i%prime[j]==0) { phi[prime[j]*i]=phi[i]*prime[j]; break; } phi[prime[j]*i]=phi[i]*(prime[j]-1); } } } int main() { int i,j,k; long long ans=1; scanf("%d",&n); array(); for(i=1;i<=n;i++)ans=ans*phi[i]%MOD; printf("%d\n",ans); }
【3288】Mato矩阵 打表找规律
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。