372. 超级次方

你的任务是计算 ab 对 1337 取模,a 是一个正整数,b 是一个非常大的正整数且会以数组形式给出。

示例 1:

输入: a = 2, b = [3]

输出: 8

示例 2:

输入: a = 2, b = [1,0]

输出: 1024

PS:

我现在饱受数学的折磨,欧拉筛,欧拉函数,

(((φ(◎ロ◎;)φ)))

class Solution {
//372超级次方
public int superPow(int a ,int[] b){
int c = 1337;
int exp = 0;
int phi = euler(c);
//同余
for(int i=0;i<b.length;i++) exp = (exp*10+b[i])%1140; return qucikPow(a%1337,exp,1337);
}
//快速幂计算
public int qucikPow(int a,int b,int c){
int ans =1;
while(b>0){
if((b&1)==1){
ans = (ans*a)%c;
}
b >>=1;
a = (a*a)%c;
}
return ans;
}
//欧拉函数
public int euler(int n){
int ret= n;
for(int i=2;i*i<n;i++){
if(n%i==0){//n的质因数
ret = ret/n*(n-1); //欧拉函数公式
while(n%i==0){//去掉质因数i
n/=i;
}
}
}
if(n>1){//n本来就是质数 f(n) = n-1;
ret = ret/n*(n-1);
}
return ret;
} }

最新文章

  1. 我这么玩Web Api(一):帮助页面或用户手册(Microsoft and Swashbuckle Help Page)
  2. 精通Web Analytics 2.0 (7) 第五章:荣耀之钥:度量成功
  3. 【巩固】Bootstrap笔记一
  4. HTTP 初步知识总结
  5. 如何查询Oracle中用户所有信息
  6. 电赛总结(四)&mdash;&mdash;波形发生芯片总结之AD9854
  7. 使用javaScript解决asp.net中mvc使用ajax提交数组参数的匹配问题
  8. 【转】10个你必须掌握的超酷VI命令技巧
  9. [转]Inside Swift
  10. find the closest sum to a target value
  11. Pearson相关系数
  12. ajax(20161110)
  13. Java基础(3) -字符串
  14. linux服务器上Apache配置多域名
  15. 面试之路(7)-BAT面试题之计算机的三大原则
  16. 瑞芯微RK3188摄像头相关参数的配置
  17. 使用PrerenderSpaPlugin预渲染插件没有成功渲染
  18. 【转】关于免费SSL证书的那些事儿
  19. Lucene Query In Kibana
  20. Spring 中面向AOP之一系列做法

热门文章

  1. Pytest 单元测试框架
  2. 3-JVM垃圾回收算法和垃圾收集器
  3. 老板:kill -9 的原理都不知道就敢去线上执行?明天不用来了!
  4. CF#633C Spy Syndrome 2 DP+二分+hash
  5. 设计模式之GOF23原型模式02
  6. Redis学习笔记(七) 数据库
  7. 数学分析新讲(1) NOTE
  8. xml rpc SimpleXMLRPCServer [python]
  9. C#/VB.NET 将SVG图片添加到PDF、转换为PDF
  10. POJ1321棋盘问题(DFS)