算法题每日一练---第61天:数的幂次

简介: 给定三个正整数 N、M、P,求解N^MmodP的具体值。

2.png

一、问题描述


给定三个正整数 N、M、P,求解N^MmodP的具体值。


第 1 行为一个整数 T,表示测试数据数量。


接下来的 T 行每行包含三个正整数 N、M、P,1≤T≤10^5,1≤N,M,P≤10^9。

输出N^MmodP的结果。


题目链接:数的幂次


二、题目要求


样例

输入:
3 
2 3 7 
4 5 6 
5 2 9
输出:
1 
4 
7


考察

位运算中等题型、快速幂
建议用时15~30min


三、问题分析


本题是位运算的第16题,没了解过位运算相关知识点可以看这一篇文章,讲解比较详细:

算法题每日一练---第45天:位运算


如果你了解过位运算相关知识点,但没有了解过快速幂,可以先看这一篇

算法题每日一练---第60天:快速幂


这一题的数据量比较大,如果用普通的次方相乘取模运算肯定会超时的,而用快速幂最多也只需要计算32位就可以完成计算,为了保险起见我们用64的long long 存储。


四、编码实现


#include<iostream>#include<math.h>usingnamespacestd;
typedeflonglongll;//定义long longllquick_pow(lln,llm,llp)//快速幂模板{
llans=1,base=n;
while(m!=0)
    {
if(m&1)
ans=(ans*base)%p;
base=(base*base)%p;
m=m>>1;
    }
returnans;
}
intmain()
{
llt,n,m,p,i;//初始化数据cin>>t;
for(i=0;i<t;i++)//循环判断    {
cin>>n>>m>>p;
cout<<quick_pow(n,m,p)<<"\n";//输出结果    }
return0;
}

五、测试结果19.png

相关文章
|
3月前
|
算法 Java 程序员
【算法每日一练及解题思路】有n级台阶,一次只能上1级或2级,共有多少种走法?
本文深入解析了“爬楼梯问题”,探讨了递归与迭代两种解法,并提供了Java代码实现。通过分析问题本质,帮助读者理解动态规划技巧,提高解决实际编程问题的能力。关键词:Java, 算法, 动态规划, 爬楼梯问题, 递归, 迭代。
138 0
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
203 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
163 1
算法题每日一练---第76天:丑数 l
|
算法
算法题每日一练---第75天:Nim 游戏
你和你的朋友,两个人一起玩 Nim 游戏。
334 0
算法题每日一练---第75天:Nim 游戏
|
算法
算法题每日一练---第74天:快乐数
编写一个算法来判断一个数 n 是不是快乐数。
191 0
算法题每日一练---第74天:快乐数
|
存储 算法
算法题每日一练---第73天:加一
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
174 0
算法题每日一练---第73天:加一
|
算法
算法题每日一练---第72天:数字 1 的个数
给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。
242 0
算法题每日一练---第72天:数字 1 的个数
|
存储 算法
算法题每日一练---第71天:回文数
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
171 0
算法题每日一练---第71天:回文数