假设我们给定了f(x)=(x ^ 6 + x ^ 2 + 9894845)%971的函数,现在对于给定的x值,我们必须找到f(x)的值。
因此,如果输入为5,则输出为469
为了解决这个问题,我们将遵循以下步骤-
定义一个函数power_mod(),它将采用基数,指数,模数,
base:=基本模数
结果:= 1
当指数> 0时,执行-
结果:=(结果*基数)模数
如果指数是奇数,则-
基本:=(基本*基本)模数
指数=指数/ 2
返回结果
从主要方法中执行以下操作-
返回power_mod(n,6,m)+ power_mod(n,2,m))mod m + 355)mod m
让我们看下面的实现以更好地理解-
#include <bits/stdc++.h>
using namespace std;
typedef long long int lli;
lli power_mod(lli base, lli exponent, lli modulus) {
base %= modulus;
lli result = 1;
while (exponent > 0) {
if (exponent & 1)
result = (result * base) % modulus;
base = (base * base) % modulus;
exponent >>= 1;
}
return result;
}
int main(){
lli n = 654654, m = 971;
cout<<(((power_mod(n, 6, m)+power_mod(n, 2, m))% m + 355)% m);
}84562
输出结果
450