magic

题解

首先原式指数肯定会爆$long$ $long$

首先根据欧拉定理我们可以将原式换成$N^{\sum\limits_{i=1}^{i<=N} [gcd(i,N)==1] C_{G}^{i}  \%phi(p)}\%p$

根据欧拉函数是积性的得出$phi(54184622)=phi(2)*phi(27092311)$

然后$phi(27092311)=27092310$  $phi(2)=1$所以$phi(54184622)=27092310$

于是我们现在要求的就是$N^{\sum\limits_{i=1}^{i<=N} [gcd(i,N)==1] C_{G}^{i}  \%27092310}\%p$

$27092310=2*3*5*7*129011$然后裸的$crt$求组合数板子求就完了

注意:你要预处理出阶乘和逆元,否则会超时

代码

#include<bits/stdc++.h>
#define ll long long
#define A 333333
ll k,p,n,g;
//phi(54184622)=27092310
//27092310=2*3*5*7*129011
ll w[7]={0,2,3,5,7,129011,54184622},jie[6][A],ni[6][A],dl[A],b[A];
ll exgcd(ll a,ll b,ll &x,ll &y){
if(b==0){
x=1;y=0;
return a;
}
ll gcd=exgcd(b,a%b,x,y);
ll t=x;
x=y;
y=t-a/b*y;
return gcd;
}
ll meng(ll x,ll k,ll cix){
ll ans=1;
for(;k;k>>=1,x=x*x%w[cix])
if(k&1)
ans=ans*x%w[cix];
return ans;
}
ll china(){
ll x,y,a=0,m,n=1;
for(ll i=1;i<=5;i++)
n*=w[i];
for(ll i=1;i<=5;i++){
m=n/w[i];
exgcd(w[i],m,x,y);
a=(a+y*m*b[i])%n;
}
if(a>0) return a;
return a+n;
}
ll gcd(ll x,ll y){
if(y==0) return x;
return gcd(y,x%y);
}
ll jic(ll n,ll m,ll cix){
if(m>n) return 0;
if(m==0) return 1;
return jie[cix][n]%w[cix]*ni[cix][n-m]%w[cix]*ni[cix][m]%w[cix];
}
ll lucas(ll n,ll m,ll cix){
if(n==0)return 1;
return jic(n%w[cix],m%w[cix],cix)*lucas(n/w[cix],m/w[cix],cix)%w[cix];
}
using namespace std;
int main()
{
scanf("%lld%lld",&n,&g);
for(ll i=1;i<=min(g,n);i++){
if(gcd(i,n)==1)
dl[++dl[0]]=i;
}
for(ll i=1;i<=5;i++){
jie[i][0]=1;
ni[i][0]=1;
for(ll j=1;j<w[i];j++)
jie[i][j]=jie[i][j-1]*j%w[i];
ni[i][w[i]-1]=meng(jie[i][w[i]-1],w[i]-2,i);
for(ll j=w[i]-2;j>=1;j--)
ni[i][j]=ni[i][j+1]*(j+1)%w[i];
for(ll j=1;j<=dl[0];j++)
(b[i]+=lucas(g,dl[j],i))%=w[i];
}
ll j=china();
ll k=meng(n,j,6);
cout<<k<<endl;
//模w「i」 剩余b「i」
}

one

题解

美妙的约瑟夫问题,

范围特别大考虑线性推

然而我懒的说了

代码特别简单,只是上文稍做修改

代码

#include<bits/stdc++.h>
using namespace std;
#define ll int
#define A 1000000
ll ans,t,n;
int main(){
scanf("%d",&t);
while(t--){
scanf("%d",&n);
ans=0;
for(ll i=n-1;i>=0;i--)
ans=(ans+i)%(n-i+1);
printf("%d\n",ans+1);
}
}

return

题解

这是道语文题,这一定是一个语文题,一定是这样

其实它是让你求前趋后继

那么这个题难点就在于怎么在作者给出题干中看出是前趋后继

那么我们看题干

  

     $0-2^{31}$范围内

我真的没看出来这是求前趋后继,$pdf$上没给样例解释

NOIP模拟测试30「return·one·magic」的更多相关文章

  1. NOIP模拟测试19「count·dinner·chess」

    反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...

  2. NOIP模拟测试16「Drink·blue·weed」

    话说这次考试 Drink 非常棒的一道卡常练习题,适合练习卡常 真的很棒 前置卡常知识 1.char要比int快 char是最快的 输出putchar,输入getchar 在这个题快了7000豪 2. ...

  3. NOIP模拟测试38「金·斯诺·赤」

    金 辗转相减见祖宗 高精 #include<bits/stdc++.h> using namespace std; #define A 2000 #define P 1 #define N ...

  4. NOIP模拟测试28「阴阳·虎·山洞」

    写这几个题解我觉得我就像在按照官方题解抄一样 阴阳 题解 将题目中给的阴阳看作黑色和白色 首先我们观察到最后生成图中某种颜色必须是竖着单调递增或竖着单调递减 类似这样 否则不满足这个条件 但合法染色方 ...

  5. NOIP模拟测试20「周·任·飞」

    liu_runda出的题再次$\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%$ 任 题解 题目中为什么反复强调简单路径,没有环 没有环的图中点数-边数=联通块数 前缀和维护边 ...

  6. NOIP模拟测试23「mine·water·gcd」

    mine 题解 一道比较水的dp 考试因为初始化挂掉了只有$80$分 代码有注释 #include<bits/stdc++.h> using namespace std; //无脑dp # ...

  7. NOIP模拟测试9「随·单·题」

    liu_runda出的题,先$\%\%\%\%\%\%\%\%\%\%\%$为敬 随 考试时没有Qj 然后甚至没做,甚至没交 我不知道我怎么想的 这个题挺难改 你需要用到 循环矩阵快速幂,矩阵快速幂优 ...

  8. NOIP模拟测试4「礼物·通讯·奇袭」

    礼物. 首先见到期望一定要想dp,看到n的范围无脑想状压, 然后我就只想到这了. dp方程式还是比较好想的,但是我依然想不出来 略经思考   颓题解 依然不会,随便写了个式子 i状态中不含j $f[i ...

  9. NOIP模拟测试10「大佬·辣鸡·模板」

    大佬 显然假期望 我奇思妙想出了一个式子$f[i]=f[i-1]+\sum\limits_{j=1}^{j<=m} C_{k \times j}^{k}\times w[j]$ 然后一想不对得容 ...

随机推荐

  1. 大学四年因为分享了这些软件测试常用软件,我成了别人眼中的(lei)大神(feng)!

    依稀记得,毕业那天,我们辅导员发给我毕业证的时候对我说"你可是咱们系的风云人物啊",哎呀,别提当时多开心啦????,嗯,我们辅导员是所有辅导员中最漂亮的一个,真的???? 不过,辅 ...

  2. .Net Core平台下,添加包的引用

    一个程序的开发过程中离不开对程序集(Assembly,将程序集打包好,就成为一个.dll的包文件,它也叫动态链接库(Dynamic Link Library​))的依赖,在以前ASP.Net时代,微软 ...

  3. Swift系列七 - 汇编分析值类型

    通过汇编分下值类型的本质. 一.值类型 值类型赋值给var,let或者给参数传参,是直接将所有内容拷贝一份.类似于对文件进行复制粘贴操作,产生了全新的文件副本,属于深拷贝(deep copy). 示例 ...

  4. [bug] conda:Segmentation fault (core dumped)

    参考 https://www.jianshu.com/p/5e230ef8a14d

  5. [java] Maven安装本地jar包

    命令 mvn install:install-file -Dfile="E:\software\Apache\repository\org\apache\flink\flink-connec ...

  6. [bug] CDH报错:cloudera-scm-server dead but pid file exists

    参考 https://blog.csdn.net/levy_cui/article/details/51243335

  7. [刷题] 349 Intersection of Two Arrays

    查找问题 查找有无(只有键) 元素'a'是否存在 set(集合) 查找对应关系(键值对应) 元素'a'出现了几次 map(字典) set和map的底层实现是红黑树 常见操作 insert() find ...

  8. dpkg -S {file} #ubuntu 14.04 rpm -qf {file} #centos 7

    Linux查找命令或组件对应安装包的方法原创FJEagle 最后发布于2017-12-15 19:10:06 阅读数 4603 收藏展开Linux查找命令或组件对应安装包的方法当新搭建服务器或者维护不 ...

  9. STM32的时钟系统RCC详细整理(转载)

    一.综述: 1.时钟源 在 STM32 中,一共有 5 个时钟源,分别是 HSI . HSE . LSI . LSE . PLL . ①HSI 是高速内部时钟, RC 振荡器,频率为 8MHz : ② ...

  10. JMicro微服务之超时&重试

    JMicro是本人开发的基于Java实现的微服务框架,当前正式版本为0.0.3,并已发布到maven中央仓库.项目源码github:https://github.com/mynewworldyyl/j ...