题目链接:传送门

题目要求:求S(2004^x)%29。

题目解析:因子和函数为乘性函数,所以首先质因子分解s(2004^x)=s(2^2*x)*s(3^x)*s(167^x);

因为2与29,166与29互质,所以都存在逆元,直接解就可以。刚开始做的时候这题困扰了我很长时间。

这是我之前没怎么看懂的原因:同余性质  : 若 a=b(mod m) 则 a^k=b^k (mod m):
所以 167可以用 22代替,(对29 同余)

167%29==22%29

169^x%29==22^x%29

而为什么s(167^x)%29=(167^x+1 -1)/166%mod=(((167%29)^x+1 -1)%mod/(166%mod))%mod=(22^x+1 -1)/21%mod,但是我不怎么懂,他们为什么直接

根据s(167^x)%mod==s(22^x)%mod,现在貌似懂了。

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <math.h>
#define mod 29
using namespace std;
typedef long long ll;
ll mpow(ll x,ll k)
{
ll t=;
while(k)
{
if(k&) t=((t%mod)*(x%mod))%mod;
k>>=;
x=((x%mod)*(x%mod))%mod;
}
return t;
}
ll X,Y;
void extend(ll A,ll B,ll &x1,ll &y1)
{
if(B==)
{
x1=;
y1=;
return ;
}
extend(B,A%B,x1,y1);
ll t=x1;
x1=y1;
y1=t-(A/B)*y1;
}
int main()
{
int n;
ll a,b,c,sum,temp;
while(scanf("%d",&n)!=EOF&&n!=)
{
sum=;
temp=*n+;
a=mpow(,temp);
a=(a-)%mod;
b=mpow(,n+);
b=(b-)%mod;
b=(b*)%mod;
c=mpow(,n+);
c=(c-)%mod;
extend(,,X,Y);
X=(X%mod+mod)%mod;
c=(c*X)%mod;
sum=((a%mod)*(b%mod)*(c%mod))%mod;
printf("%I64d\n",sum);
}
return ;
}

最新文章

  1. c语言结构体
  2. 开启关闭keditor 过滤
  3. Android 开源框架Universal-Image-Loader完全解析(三)---源代码解读
  4. 使用uboot的tftp下载bootloader、内核、文件系统
  5. opencv的学习笔记4
  6. 使用.htaccess进行浏览器图片文件缓存
  7. Java 编程的动态性,第 5 部分: 动态转换类--转载
  8. 使用AsyncTask实现图片加载
  9. JS 不定函数参数argument的用法
  10. 保存属性至xml并读取
  11. 利用VNC远程登录Linux服务器简易版
  12. git push 报错 &quot;Peer certificate cannot be authenticated with known CA certificates&quot;
  13. kubernetes系列08—service资源详解
  14. 使用 boot-repair 对 Windows + Ubuntu 双系统引导修复
  15. mac subLime3 JSON 格式化插件安装
  16. 我的Netty笔记
  17. BOM 表
  18. Learning to rank相关的pointwise,pairwise,listwise
  19. 用mongoose实现mongodb增删改查
  20. (最小生成树)Agri-Net -- POJ -- 1258

热门文章

  1. linux环境判断字符串是否为非空
  2. oracle之trunc(sysdate)
  3. SQLServer------如何让标识列重新开始计算
  4. Recurrent Neural Network Language Modeling Toolkit代码学习
  5. H5 readfile 多图片预览
  6. 查看网卡流量:nload
  7. #error和line
  8. STM32学习之路之入门篇
  9. php之常量
  10. JS基本动画