欧拉定理的C ++程序
这是一个C++程序,它演示了Euler定理的实现。数字和模数必须是互质的,才能存在模数乘法逆。
算法
Begin
Take input to find modular multiplicative inverse
Take input as modular value
Perform inverse array function:
modInverse(x + 1, 0);
modInverse[1] = 1;
for i = 2 to x
modInverse[i] = (-(y / i) * modInverse[y mod i]) mod y + y
return modInverse
End范例程式码
#include <iostream>
#include <vector>
using namespace std;
vector<int> inverseArray(int x, int y) {
vector<int> modInverse(x + 1, 0);
modInverse[1] = 1;
for (int i = 2; i <= x; i++) {
modInverse[i] = (-(y / i) * modInverse[y % i]) % y + y;
}
return modInverse;
}
int main() {
vector<int>::iterator it;
int a, m;
cout<<"Enter number to find modular multiplicative inverse: ";
cin>>a;
cout<<"Enter Modular Value: ";
cin>>m;
cout<<inverseArray(a, m)[a]<<endl;
}输出结果
Enter number to find modular multiplicative inverse: 26 Enter Modular Value: 7 7
热门推荐
10 枣庄人事考试祝福语简短
11 年底拜年祝福语大全简短
12 新年的生日祝福语简短
13 祝产妇的祝福语简短
14 恋爱祝福语大全简短搞笑
15 小红书生日祝福语简短
16 高温早安祝福语简短精辟
17 员工对同事祝福语简短
18 讲课祝福语简短10字