问题

  Your task is to calculate ab mod 1337 where a is a positive integer and b is an extremely large positive integer given in the form of an array.

  Example1:

  a = 2
  b = [3]   Result: 8

  Example2:

  a = 2   b = [1,0]   Result: 1024

分析
  
  根据公式 ① ② ab mod 1337 可以优化为 (a mod 1337)b mod 1337 ,所以每次计算底数的时候,计算之前和之后,都进行mod,预防结果超过整数范围。
  根据公式 ③ ,可以根据题意对指数进行分解,本题的进制为10.
  根据公式 ④,对计算过程进行分解,每一步都是计算 ,由于ai知道,所以每步的计算其实是计算底数。

代码 

    int mod = ;
int superPow(int a, vector<int>& b) {
int answer = ,n = b.size();
if( n == )
return ;
for(int i = n - ;i >= ; i--)
{
if( b[i] > )
answer = answer * Inpow(a,b[i]) % mod;
a = Inpow(a,);
}
return answer;
} int Inpow(int base,int exp){
int result = ;
base = base%mod; for(int i = exp; i > ;i = i >> )
{
if( i & == )
result = result * base %mod;
base = base * base % mod;
} return result % mod; }

  

    

最新文章

  1. 最全的linux命令大全,shell运维手册
  2. &quot;互联网思维&quot;背后的谎言
  3. BZOJ1393 [Ceoi2008]knights
  4. PHP学习笔记06——面向对象版图形计算器
  5. 数据结构(12) -- 图的邻接矩阵的DFS和BFS
  6. linux命令之chown命令
  7. C#程序调用cmd执行命令(转)
  8. 大数据时代的数据存储,非关系型数据库MongoDB(一)
  9. Ext JS学习第三天 我们所熟悉的javascript(二)
  10. python内置函数(四)
  11. yii2 源码分析 Component类分析 (二)
  12. Properties类
  13. Jmeter 传 PUT 请求方式
  14. 【51nod 1785】数据流中的算法
  15. JVM系列1:Java内存区域
  16. 文件IO流
  17. 点击threadItem查看MessageList时传递数据
  18. 【Windows】DOS的常用命令
  19. selenium - switch_to.frame()- 内嵌表单的切换
  20. 安卓 Activity Fragment 生命周期

热门文章

  1. Android 样式 (style) 和主题(theme)
  2. Web应用请求和响应 HTTP相关
  3. php 使用函数中遇到的坑之----strpos
  4. 每天一个 Linux 命令(21):find命令之xargs
  5. NoSQL和MongoDB
  6. linux phpexcel导出后打不开
  7. jQuery校验
  8. Django基础,Day3 - 编写 django admin
  9. 【mysql函数】FIND_IN_SET函数用法
  10. 【WP8.1】HttpClient网络请求、进度以及终止